Commit 5107430d authored by Martin Storsjö's avatar Martin Storsjö

omxil: Convert the khronos provided headers to unix newlines

All headers except OMX_Component.h seemed to be stored with dos
newlines for some unknown reason. In the OpenMAX IL 1.1.2 header
zip file provided by Khronos, they are provided with unix newlines,
which also is the norm for the VLC codebase.
Signed-off-by: default avatarMartin Storsjö <martin@martin.st>
parent 4b325af6
This source diff could not be displayed because it is too large. You can view the blob instead.
This source diff could not be displayed because it is too large. You can view the blob instead.
/** /**
* Copyright (c) 2008 The Khronos Group Inc. * Copyright (c) 2008 The Khronos Group Inc.
* *
* Permission is hereby granted, free of charge, to any person obtaining * Permission is hereby granted, free of charge, to any person obtaining
* a copy of this software and associated documentation files (the * a copy of this software and associated documentation files (the
* "Software"), to deal in the Software without restriction, including * "Software"), to deal in the Software without restriction, including
* without limitation the rights to use, copy, modify, merge, publish, * without limitation the rights to use, copy, modify, merge, publish,
* distribute, sublicense, and/or sell copies of the Software, and to * distribute, sublicense, and/or sell copies of the Software, and to
* permit persons to whom the Software is furnished to do so, subject * permit persons to whom the Software is furnished to do so, subject
* to the following conditions: * to the following conditions:
* The above copyright notice and this permission notice shall be included * The above copyright notice and this permission notice shall be included
* in all copies or substantial portions of the Software. * in all copies or substantial portions of the Software.
* *
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
* OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, * CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
* *
*/ */
/** /**
* @file OMX_IVCommon.h - OpenMax IL version 1.1.2 * @file OMX_IVCommon.h - OpenMax IL version 1.1.2
* The structures needed by Video and Image components to exchange * The structures needed by Video and Image components to exchange
* parameters and configuration data with the components. * parameters and configuration data with the components.
*/ */
#ifndef OMX_IVCommon_h #ifndef OMX_IVCommon_h
#define OMX_IVCommon_h #define OMX_IVCommon_h
#ifdef __cplusplus #ifdef __cplusplus
extern "C" { extern "C" {
#endif /* __cplusplus */ #endif /* __cplusplus */
/** /**
* Each OMX header must include all required header files to allow the header * Each OMX header must include all required header files to allow the header
* to compile without errors. The includes below are required for this header * to compile without errors. The includes below are required for this header
* file to compile successfully * file to compile successfully
*/ */
#include <OMX_Core.h> #include <OMX_Core.h>
/** @defgroup iv OpenMAX IL Imaging and Video Domain /** @defgroup iv OpenMAX IL Imaging and Video Domain
* Common structures for OpenMAX IL Imaging and Video domains * Common structures for OpenMAX IL Imaging and Video domains
* @{ * @{
*/ */
/** /**
* Enumeration defining possible uncompressed image/video formats. * Enumeration defining possible uncompressed image/video formats.
* *
* ENUMS: * ENUMS:
* Unused : Placeholder value when format is N/A * Unused : Placeholder value when format is N/A
* Monochrome : black and white * Monochrome : black and white
* 8bitRGB332 : Red 7:5, Green 4:2, Blue 1:0 * 8bitRGB332 : Red 7:5, Green 4:2, Blue 1:0
* 12bitRGB444 : Red 11:8, Green 7:4, Blue 3:0 * 12bitRGB444 : Red 11:8, Green 7:4, Blue 3:0
* 16bitARGB4444 : Alpha 15:12, Red 11:8, Green 7:4, Blue 3:0 * 16bitARGB4444 : Alpha 15:12, Red 11:8, Green 7:4, Blue 3:0
* 16bitARGB1555 : Alpha 15, Red 14:10, Green 9:5, Blue 4:0 * 16bitARGB1555 : Alpha 15, Red 14:10, Green 9:5, Blue 4:0
* 16bitRGB565 : Red 15:11, Green 10:5, Blue 4:0 * 16bitRGB565 : Red 15:11, Green 10:5, Blue 4:0
* 16bitBGR565 : Blue 15:11, Green 10:5, Red 4:0 * 16bitBGR565 : Blue 15:11, Green 10:5, Red 4:0
* 18bitRGB666 : Red 17:12, Green 11:6, Blue 5:0 * 18bitRGB666 : Red 17:12, Green 11:6, Blue 5:0
* 18bitARGB1665 : Alpha 17, Red 16:11, Green 10:5, Blue 4:0 * 18bitARGB1665 : Alpha 17, Red 16:11, Green 10:5, Blue 4:0
* 19bitARGB1666 : Alpha 18, Red 17:12, Green 11:6, Blue 5:0 * 19bitARGB1666 : Alpha 18, Red 17:12, Green 11:6, Blue 5:0
* 24bitRGB888 : Red 24:16, Green 15:8, Blue 7:0 * 24bitRGB888 : Red 24:16, Green 15:8, Blue 7:0
* 24bitBGR888 : Blue 24:16, Green 15:8, Red 7:0 * 24bitBGR888 : Blue 24:16, Green 15:8, Red 7:0
* 24bitARGB1887 : Alpha 23, Red 22:15, Green 14:7, Blue 6:0 * 24bitARGB1887 : Alpha 23, Red 22:15, Green 14:7, Blue 6:0
* 25bitARGB1888 : Alpha 24, Red 23:16, Green 15:8, Blue 7:0 * 25bitARGB1888 : Alpha 24, Red 23:16, Green 15:8, Blue 7:0
* 32bitBGRA8888 : Blue 31:24, Green 23:16, Red 15:8, Alpha 7:0 * 32bitBGRA8888 : Blue 31:24, Green 23:16, Red 15:8, Alpha 7:0
* 32bitARGB8888 : Alpha 31:24, Red 23:16, Green 15:8, Blue 7:0 * 32bitARGB8888 : Alpha 31:24, Red 23:16, Green 15:8, Blue 7:0
* YUV411Planar : U,Y are subsampled by a factor of 4 horizontally * YUV411Planar : U,Y are subsampled by a factor of 4 horizontally
* YUV411PackedPlanar : packed per payload in planar slices * YUV411PackedPlanar : packed per payload in planar slices
* YUV420Planar : Three arrays Y,U,V. * YUV420Planar : Three arrays Y,U,V.
* YUV420PackedPlanar : packed per payload in planar slices * YUV420PackedPlanar : packed per payload in planar slices
* YUV420SemiPlanar : Two arrays, one is all Y, the other is U and V * YUV420SemiPlanar : Two arrays, one is all Y, the other is U and V
* YUV422Planar : Three arrays Y,U,V. * YUV422Planar : Three arrays Y,U,V.
* YUV422PackedPlanar : packed per payload in planar slices * YUV422PackedPlanar : packed per payload in planar slices
* YUV422SemiPlanar : Two arrays, one is all Y, the other is U and V * YUV422SemiPlanar : Two arrays, one is all Y, the other is U and V
* YCbYCr : Organized as 16bit YUYV (i.e. YCbYCr) * YCbYCr : Organized as 16bit YUYV (i.e. YCbYCr)
* YCrYCb : Organized as 16bit YVYU (i.e. YCrYCb) * YCrYCb : Organized as 16bit YVYU (i.e. YCrYCb)
* CbYCrY : Organized as 16bit UYVY (i.e. CbYCrY) * CbYCrY : Organized as 16bit UYVY (i.e. CbYCrY)
* CrYCbY : Organized as 16bit VYUY (i.e. CrYCbY) * CrYCbY : Organized as 16bit VYUY (i.e. CrYCbY)
* YUV444Interleaved : Each pixel contains equal parts YUV * YUV444Interleaved : Each pixel contains equal parts YUV
* RawBayer8bit : SMIA camera output format * RawBayer8bit : SMIA camera output format
* RawBayer10bit : SMIA camera output format * RawBayer10bit : SMIA camera output format
* RawBayer8bitcompressed : SMIA camera output format * RawBayer8bitcompressed : SMIA camera output format
*/ */
typedef enum OMX_COLOR_FORMATTYPE { typedef enum OMX_COLOR_FORMATTYPE {
OMX_COLOR_FormatUnused, OMX_COLOR_FormatUnused,
OMX_COLOR_FormatMonochrome, OMX_COLOR_FormatMonochrome,
OMX_COLOR_Format8bitRGB332, OMX_COLOR_Format8bitRGB332,
OMX_COLOR_Format12bitRGB444, OMX_COLOR_Format12bitRGB444,
OMX_COLOR_Format16bitARGB4444, OMX_COLOR_Format16bitARGB4444,
OMX_COLOR_Format16bitARGB1555, OMX_COLOR_Format16bitARGB1555,
OMX_COLOR_Format16bitRGB565, OMX_COLOR_Format16bitRGB565,
OMX_COLOR_Format16bitBGR565, OMX_COLOR_Format16bitBGR565,
OMX_COLOR_Format18bitRGB666, OMX_COLOR_Format18bitRGB666,
OMX_COLOR_Format18bitARGB1665, OMX_COLOR_Format18bitARGB1665,
OMX_COLOR_Format19bitARGB1666, OMX_COLOR_Format19bitARGB1666,
OMX_COLOR_Format24bitRGB888, OMX_COLOR_Format24bitRGB888,
OMX_COLOR_Format24bitBGR888, OMX_COLOR_Format24bitBGR888,
OMX_COLOR_Format24bitARGB1887, OMX_COLOR_Format24bitARGB1887,
OMX_COLOR_Format25bitARGB1888, OMX_COLOR_Format25bitARGB1888,
OMX_COLOR_Format32bitBGRA8888, OMX_COLOR_Format32bitBGRA8888,
OMX_COLOR_Format32bitARGB8888, OMX_COLOR_Format32bitARGB8888,
OMX_COLOR_FormatYUV411Planar, OMX_COLOR_FormatYUV411Planar,
OMX_COLOR_FormatYUV411PackedPlanar, OMX_COLOR_FormatYUV411PackedPlanar,
OMX_COLOR_FormatYUV420Planar, OMX_COLOR_FormatYUV420Planar,
OMX_COLOR_FormatYUV420PackedPlanar, OMX_COLOR_FormatYUV420PackedPlanar,
OMX_COLOR_FormatYUV420SemiPlanar, OMX_COLOR_FormatYUV420SemiPlanar,
OMX_COLOR_FormatYUV422Planar, OMX_COLOR_FormatYUV422Planar,
OMX_COLOR_FormatYUV422PackedPlanar, OMX_COLOR_FormatYUV422PackedPlanar,
OMX_COLOR_FormatYUV422SemiPlanar, OMX_COLOR_FormatYUV422SemiPlanar,
OMX_COLOR_FormatYCbYCr, OMX_COLOR_FormatYCbYCr,
OMX_COLOR_FormatYCrYCb, OMX_COLOR_FormatYCrYCb,
OMX_COLOR_FormatCbYCrY, OMX_COLOR_FormatCbYCrY,
OMX_COLOR_FormatCrYCbY, OMX_COLOR_FormatCrYCbY,
OMX_COLOR_FormatYUV444Interleaved, OMX_COLOR_FormatYUV444Interleaved,
OMX_COLOR_FormatRawBayer8bit, OMX_COLOR_FormatRawBayer8bit,
OMX_COLOR_FormatRawBayer10bit, OMX_COLOR_FormatRawBayer10bit,
OMX_COLOR_FormatRawBayer8bitcompressed, OMX_COLOR_FormatRawBayer8bitcompressed,
OMX_COLOR_FormatL2, OMX_COLOR_FormatL2,
OMX_COLOR_FormatL4, OMX_COLOR_FormatL4,
OMX_COLOR_FormatL8, OMX_COLOR_FormatL8,
OMX_COLOR_FormatL16, OMX_COLOR_FormatL16,
OMX_COLOR_FormatL24, OMX_COLOR_FormatL24,
OMX_COLOR_FormatL32, OMX_COLOR_FormatL32,
OMX_COLOR_FormatYUV420PackedSemiPlanar, OMX_COLOR_FormatYUV420PackedSemiPlanar,
OMX_COLOR_FormatYUV422PackedSemiPlanar, OMX_COLOR_FormatYUV422PackedSemiPlanar,
OMX_COLOR_Format18BitBGR666, OMX_COLOR_Format18BitBGR666,
OMX_COLOR_Format24BitARGB6666, OMX_COLOR_Format24BitARGB6666,
OMX_COLOR_Format24BitABGR6666, OMX_COLOR_Format24BitABGR6666,
OMX_COLOR_FormatKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */ OMX_COLOR_FormatKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */
OMX_COLOR_FormatVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */ OMX_COLOR_FormatVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */
OMX_COLOR_FormatMax = 0x7FFFFFFF OMX_COLOR_FormatMax = 0x7FFFFFFF
} OMX_COLOR_FORMATTYPE; } OMX_COLOR_FORMATTYPE;
/** /**
* Defines the matrix for conversion from RGB to YUV or vice versa. * Defines the matrix for conversion from RGB to YUV or vice versa.
* iColorMatrix should be initialized with the fixed point values * iColorMatrix should be initialized with the fixed point values
* used in converting between formats. * used in converting between formats.
*/ */
typedef struct OMX_CONFIG_COLORCONVERSIONTYPE { typedef struct OMX_CONFIG_COLORCONVERSIONTYPE {
OMX_U32 nSize; /**< Size of the structure in bytes */ OMX_U32 nSize; /**< Size of the structure in bytes */
OMX_VERSIONTYPE nVersion; /**< OMX specification version info */ OMX_VERSIONTYPE nVersion; /**< OMX specification version info */
OMX_U32 nPortIndex; /**< Port that this struct applies to */ OMX_U32 nPortIndex; /**< Port that this struct applies to */
OMX_S32 xColorMatrix[3][3]; /**< Stored in signed Q16 format */ OMX_S32 xColorMatrix[3][3]; /**< Stored in signed Q16 format */
OMX_S32 xColorOffset[4]; /**< Stored in signed Q16 format */ OMX_S32 xColorOffset[4]; /**< Stored in signed Q16 format */
}OMX_CONFIG_COLORCONVERSIONTYPE; }OMX_CONFIG_COLORCONVERSIONTYPE;
/** /**
* Structure defining percent to scale each frame dimension. For example: * Structure defining percent to scale each frame dimension. For example:
* To make the width 50% larger, use fWidth = 1.5 and to make the width * To make the width 50% larger, use fWidth = 1.5 and to make the width
* 1/2 the original size, use fWidth = 0.5 * 1/2 the original size, use fWidth = 0.5
*/ */
typedef struct OMX_CONFIG_SCALEFACTORTYPE { typedef struct OMX_CONFIG_SCALEFACTORTYPE {
OMX_U32 nSize; /**< Size of the structure in bytes */ OMX_U32 nSize; /**< Size of the structure in bytes */
OMX_VERSIONTYPE nVersion; /**< OMX specification version info */ OMX_VERSIONTYPE nVersion; /**< OMX specification version info */
OMX_U32 nPortIndex; /**< Port that this struct applies to */ OMX_U32 nPortIndex; /**< Port that this struct applies to */
OMX_S32 xWidth; /**< Fixed point value stored as Q16 */ OMX_S32 xWidth; /**< Fixed point value stored as Q16 */
OMX_S32 xHeight; /**< Fixed point value stored as Q16 */ OMX_S32 xHeight; /**< Fixed point value stored as Q16 */
}OMX_CONFIG_SCALEFACTORTYPE; }OMX_CONFIG_SCALEFACTORTYPE;
/** /**
* Enumeration of possible image filter types * Enumeration of possible image filter types
*/ */
typedef enum OMX_IMAGEFILTERTYPE { typedef enum OMX_IMAGEFILTERTYPE {
OMX_ImageFilterNone, OMX_ImageFilterNone,
OMX_ImageFilterNoise, OMX_ImageFilterNoise,
OMX_ImageFilterEmboss, OMX_ImageFilterEmboss,
OMX_ImageFilterNegative, OMX_ImageFilterNegative,
OMX_ImageFilterSketch, OMX_ImageFilterSketch,
OMX_ImageFilterOilPaint, OMX_ImageFilterOilPaint,
OMX_ImageFilterHatch, OMX_ImageFilterHatch,
OMX_ImageFilterGpen, OMX_ImageFilterGpen,
OMX_ImageFilterAntialias, OMX_ImageFilterAntialias,
OMX_ImageFilterDeRing, OMX_ImageFilterDeRing,
OMX_ImageFilterSolarize, OMX_ImageFilterSolarize,
OMX_ImageFilterKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */ OMX_ImageFilterKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */
OMX_ImageFilterVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */ OMX_ImageFilterVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */
OMX_ImageFilterMax = 0x7FFFFFFF OMX_ImageFilterMax = 0x7FFFFFFF
} OMX_IMAGEFILTERTYPE; } OMX_IMAGEFILTERTYPE;
/** /**
* Image filter configuration * Image filter configuration
* *
* STRUCT MEMBERS: * STRUCT MEMBERS:
* nSize : Size of the structure in bytes * nSize : Size of the structure in bytes
* nVersion : OMX specification version information * nVersion : OMX specification version information
* nPortIndex : Port that this structure applies to * nPortIndex : Port that this structure applies to
* eImageFilter : Image filter type enumeration * eImageFilter : Image filter type enumeration
*/ */
typedef struct OMX_CONFIG_IMAGEFILTERTYPE { typedef struct OMX_CONFIG_IMAGEFILTERTYPE {
OMX_U32 nSize; OMX_U32 nSize;
OMX_VERSIONTYPE nVersion; OMX_VERSIONTYPE nVersion;
OMX_U32 nPortIndex; OMX_U32 nPortIndex;
OMX_IMAGEFILTERTYPE eImageFilter; OMX_IMAGEFILTERTYPE eImageFilter;
} OMX_CONFIG_IMAGEFILTERTYPE; } OMX_CONFIG_IMAGEFILTERTYPE;
/** /**
* Customized U and V for color enhancement * Customized U and V for color enhancement
* *
* STRUCT MEMBERS: * STRUCT MEMBERS:
* nSize : Size of the structure in bytes * nSize : Size of the structure in bytes
* nVersion : OMX specification version information * nVersion : OMX specification version information
* nPortIndex : Port that this structure applies to * nPortIndex : Port that this structure applies to
* bColorEnhancement : Enable/disable color enhancement * bColorEnhancement : Enable/disable color enhancement
* nCustomizedU : Practical values: 16-240, range: 0-255, value set for * nCustomizedU : Practical values: 16-240, range: 0-255, value set for
* U component * U component
* nCustomizedV : Practical values: 16-240, range: 0-255, value set for * nCustomizedV : Practical values: 16-240, range: 0-255, value set for
* V component * V component
*/ */
typedef struct OMX_CONFIG_COLORENHANCEMENTTYPE { typedef struct OMX_CONFIG_COLORENHANCEMENTTYPE {
OMX_U32 nSize; OMX_U32 nSize;
OMX_VERSIONTYPE nVersion; OMX_VERSIONTYPE nVersion;
OMX_U32 nPortIndex; OMX_U32 nPortIndex;
OMX_BOOL bColorEnhancement; OMX_BOOL bColorEnhancement;
OMX_U8 nCustomizedU; OMX_U8 nCustomizedU;
OMX_U8 nCustomizedV; OMX_U8 nCustomizedV;
} OMX_CONFIG_COLORENHANCEMENTTYPE; } OMX_CONFIG_COLORENHANCEMENTTYPE;
/** /**
* Define color key and color key mask * Define color key and color key mask
* *
* STRUCT MEMBERS: * STRUCT MEMBERS:
* nSize : Size of the structure in bytes * nSize : Size of the structure in bytes
* nVersion : OMX specification version information * nVersion : OMX specification version information
* nPortIndex : Port that this structure applies to * nPortIndex : Port that this structure applies to
* nARGBColor : 32bit Alpha, Red, Green, Blue Color * nARGBColor : 32bit Alpha, Red, Green, Blue Color
* nARGBMask : 32bit Mask for Alpha, Red, Green, Blue channels * nARGBMask : 32bit Mask for Alpha, Red, Green, Blue channels
*/ */
typedef struct OMX_CONFIG_COLORKEYTYPE { typedef struct OMX_CONFIG_COLORKEYTYPE {
OMX_U32 nSize; OMX_U32 nSize;
OMX_VERSIONTYPE nVersion; OMX_VERSIONTYPE nVersion;
OMX_U32 nPortIndex; OMX_U32 nPortIndex;
OMX_U32 nARGBColor; OMX_U32 nARGBColor;
OMX_U32 nARGBMask; OMX_U32 nARGBMask;
} OMX_CONFIG_COLORKEYTYPE; } OMX_CONFIG_COLORKEYTYPE;
/** /**
* List of color blend types for pre/post processing * List of color blend types for pre/post processing
* *
* ENUMS: * ENUMS:
* None : No color blending present * None : No color blending present
* AlphaConstant : Function is (alpha_constant * src) + * AlphaConstant : Function is (alpha_constant * src) +
* (1 - alpha_constant) * dst) * (1 - alpha_constant) * dst)
* AlphaPerPixel : Function is (alpha * src) + (1 - alpha) * dst) * AlphaPerPixel : Function is (alpha * src) + (1 - alpha) * dst)
* Alternate : Function is alternating pixels from src and dst * Alternate : Function is alternating pixels from src and dst
* And : Function is (src & dst) * And : Function is (src & dst)
* Or : Function is (src | dst) * Or : Function is (src | dst)
* Invert : Function is ~src * Invert : Function is ~src
*/ */
typedef enum OMX_COLORBLENDTYPE { typedef enum OMX_COLORBLENDTYPE {
OMX_ColorBlendNone, OMX_ColorBlendNone,
OMX_ColorBlendAlphaConstant, OMX_ColorBlendAlphaConstant,
OMX_ColorBlendAlphaPerPixel, OMX_ColorBlendAlphaPerPixel,
OMX_ColorBlendAlternate, OMX_ColorBlendAlternate,
OMX_ColorBlendAnd, OMX_ColorBlendAnd,
OMX_ColorBlendOr, OMX_ColorBlendOr,
OMX_ColorBlendInvert, OMX_ColorBlendInvert,
OMX_ColorBlendKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */ OMX_ColorBlendKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */
OMX_ColorBlendVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */ OMX_ColorBlendVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */
OMX_ColorBlendMax = 0x7FFFFFFF OMX_ColorBlendMax = 0x7FFFFFFF
} OMX_COLORBLENDTYPE; } OMX_COLORBLENDTYPE;
/** /**
* Color blend configuration * Color blend configuration
* *
* STRUCT MEMBERS: * STRUCT MEMBERS:
* nSize : Size of the structure in bytes * nSize : Size of the structure in bytes
* nVersion : OMX specification version information * nVersion : OMX specification version information
* nPortIndex : Port that this structure applies to * nPortIndex : Port that this structure applies to
* nRGBAlphaConstant : Constant global alpha values when global alpha is used * nRGBAlphaConstant : Constant global alpha values when global alpha is used
* eColorBlend : Color blend type enumeration * eColorBlend : Color blend type enumeration
*/ */
typedef struct OMX_CONFIG_COLORBLENDTYPE { typedef struct OMX_CONFIG_COLORBLENDTYPE {
OMX_U32 nSize; OMX_U32 nSize;
OMX_VERSIONTYPE nVersion; OMX_VERSIONTYPE nVersion;
OMX_U32 nPortIndex; OMX_U32 nPortIndex;
OMX_U32 nRGBAlphaConstant; OMX_U32 nRGBAlphaConstant;
OMX_COLORBLENDTYPE eColorBlend; OMX_COLORBLENDTYPE eColorBlend;
} OMX_CONFIG_COLORBLENDTYPE; } OMX_CONFIG_COLORBLENDTYPE;
/** /**
* Hold frame dimension * Hold frame dimension
* *
* STRUCT MEMBERS: * STRUCT MEMBERS:
* nSize : Size of the structure in bytes * nSize : Size of the structure in bytes
* nVersion : OMX specification version information * nVersion : OMX specification version information
* nPortIndex : Port that this structure applies to * nPortIndex : Port that this structure applies to
* nWidth : Frame width in pixels * nWidth : Frame width in pixels
* nHeight : Frame height in pixels * nHeight : Frame height in pixels
*/ */
typedef struct OMX_FRAMESIZETYPE { typedef struct OMX_FRAMESIZETYPE {
OMX_U32 nSize; OMX_U32 nSize;
OMX_VERSIONTYPE nVersion; OMX_VERSIONTYPE nVersion;
OMX_U32 nPortIndex; OMX_U32 nPortIndex;
OMX_U32 nWidth; OMX_U32 nWidth;
OMX_U32 nHeight; OMX_U32 nHeight;
} OMX_FRAMESIZETYPE; } OMX_FRAMESIZETYPE;
/** /**
* Rotation configuration * Rotation configuration
* *
* STRUCT MEMBERS: * STRUCT MEMBERS:
* nSize : Size of the structure in bytes * nSize : Size of the structure in bytes
* nVersion : OMX specification version information * nVersion : OMX specification version information
* nPortIndex : Port that this structure applies to * nPortIndex : Port that this structure applies to
* nRotation : +/- integer rotation value * nRotation : +/- integer rotation value
*/ */
typedef struct OMX_CONFIG_ROTATIONTYPE { typedef struct OMX_CONFIG_ROTATIONTYPE {
OMX_U32 nSize; OMX_U32 nSize;
OMX_VERSIONTYPE nVersion; OMX_VERSIONTYPE nVersion;
OMX_U32 nPortIndex; OMX_U32 nPortIndex;
OMX_S32 nRotation; OMX_S32 nRotation;
} OMX_CONFIG_ROTATIONTYPE; } OMX_CONFIG_ROTATIONTYPE;
/** /**
* Possible mirroring directions for pre/post processing * Possible mirroring directions for pre/post processing
* *
* ENUMS: * ENUMS:
* None : No mirroring * None : No mirroring
* Vertical : Vertical mirroring, flip on X axis * Vertical : Vertical mirroring, flip on X axis
* Horizontal : Horizontal mirroring, flip on Y axis * Horizontal : Horizontal mirroring, flip on Y axis
* Both : Both vertical and horizontal mirroring * Both : Both vertical and horizontal mirroring
*/ */
typedef enum OMX_MIRRORTYPE { typedef enum OMX_MIRRORTYPE {
OMX_MirrorNone = 0, OMX_MirrorNone = 0,
OMX_MirrorVertical, OMX_MirrorVertical,
OMX_MirrorHorizontal, OMX_MirrorHorizontal,
OMX_MirrorBoth, OMX_MirrorBoth,
OMX_MirrorKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */ OMX_MirrorKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */
OMX_MirrorVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */ OMX_MirrorVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */
OMX_MirrorMax = 0x7FFFFFFF OMX_MirrorMax = 0x7FFFFFFF
} OMX_MIRRORTYPE; } OMX_MIRRORTYPE;
/** /**
* Mirroring configuration * Mirroring configuration
* *
* STRUCT MEMBERS: * STRUCT MEMBERS:
* nSize : Size of the structure in bytes * nSize : Size of the structure in bytes
* nVersion : OMX specification version information * nVersion : OMX specification version information
* nPortIndex : Port that this structure applies to * nPortIndex : Port that this structure applies to
* eMirror : Mirror type enumeration * eMirror : Mirror type enumeration
*/ */
typedef struct OMX_CONFIG_MIRRORTYPE { typedef struct OMX_CONFIG_MIRRORTYPE {
OMX_U32 nSize; OMX_U32 nSize;
OMX_VERSIONTYPE nVersion; OMX_VERSIONTYPE nVersion;
OMX_U32 nPortIndex; OMX_U32 nPortIndex;
OMX_MIRRORTYPE eMirror; OMX_MIRRORTYPE eMirror;
} OMX_CONFIG_MIRRORTYPE; } OMX_CONFIG_MIRRORTYPE;
/** /**
* Position information only * Position information only
* *
* STRUCT MEMBERS: * STRUCT MEMBERS:
* nSize : Size of the structure in bytes * nSize : Size of the structure in bytes
* nVersion : OMX specification version information * nVersion : OMX specification version information
* nPortIndex : Port that this structure applies to * nPortIndex : Port that this structure applies to
* nX : X coordinate for the point * nX : X coordinate for the point
* nY : Y coordinate for the point * nY : Y coordinate for the point
*/ */
typedef struct OMX_CONFIG_POINTTYPE { typedef struct OMX_CONFIG_POINTTYPE {
OMX_U32 nSize; OMX_U32 nSize;
OMX_VERSIONTYPE nVersion; OMX_VERSIONTYPE nVersion;
OMX_U32 nPortIndex; OMX_U32 nPortIndex;
OMX_S32 nX; OMX_S32 nX;
OMX_S32 nY; OMX_S32 nY;
} OMX_CONFIG_POINTTYPE; } OMX_CONFIG_POINTTYPE;
/** /**
* Frame size plus position * Frame size plus position
* *
* STRUCT MEMBERS: * STRUCT MEMBERS:
* nSize : Size of the structure in bytes * nSize : Size of the structure in bytes
* nVersion : OMX specification version information * nVersion : OMX specification version information
* nPortIndex : Port that this structure applies to * nPortIndex : Port that this structure applies to
* nLeft : X Coordinate of the top left corner of the rectangle * nLeft : X Coordinate of the top left corner of the rectangle
* nTop : Y Coordinate of the top left corner of the rectangle * nTop : Y Coordinate of the top left corner of the rectangle
* nWidth : Width of the rectangle * nWidth : Width of the rectangle
* nHeight : Height of the rectangle * nHeight : Height of the rectangle
*/ */
typedef struct OMX_CONFIG_RECTTYPE { typedef struct OMX_CONFIG_RECTTYPE {
OMX_U32 nSize; OMX_U32 nSize;
OMX_VERSIONTYPE nVersion; OMX_VERSIONTYPE nVersion;
OMX_U32 nPortIndex; OMX_U32 nPortIndex;
OMX_S32 nLeft; OMX_S32 nLeft;
OMX_S32 nTop; OMX_S32 nTop;
OMX_U32 nWidth; OMX_U32 nWidth;
OMX_U32 nHeight; OMX_U32 nHeight;
} OMX_CONFIG_RECTTYPE; } OMX_CONFIG_RECTTYPE;
/** /**
* Deblocking state; it is required to be set up before starting the codec * Deblocking state; it is required to be set up before starting the codec
* *
* STRUCT MEMBERS: * STRUCT MEMBERS:
* nSize : Size of the structure in bytes * nSize : Size of the structure in bytes
* nVersion : OMX specification version information * nVersion : OMX specification version information
* nPortIndex : Port that this structure applies to * nPortIndex : Port that this structure applies to
* bDeblocking : Enable/disable deblocking mode * bDeblocking : Enable/disable deblocking mode
*/ */
typedef struct OMX_PARAM_DEBLOCKINGTYPE { typedef struct OMX_PARAM_DEBLOCKINGTYPE {
OMX_U32 nSize; OMX_U32 nSize;
OMX_VERSIONTYPE nVersion; OMX_VERSIONTYPE nVersion;
OMX_U32 nPortIndex; OMX_U32 nPortIndex;
OMX_BOOL bDeblocking; OMX_BOOL bDeblocking;
} OMX_PARAM_DEBLOCKINGTYPE; } OMX_PARAM_DEBLOCKINGTYPE;
/** /**
* Stabilization state * Stabilization state
* *
* STRUCT MEMBERS: * STRUCT MEMBERS:
* nSize : Size of the structure in bytes * nSize : Size of the structure in bytes
* nVersion : OMX specification version information * nVersion : OMX specification version information
* nPortIndex : Port that this structure applies to * nPortIndex : Port that this structure applies to
* bStab : Enable/disable frame stabilization state * bStab : Enable/disable frame stabilization state
*/ */
typedef struct OMX_CONFIG_FRAMESTABTYPE { typedef struct OMX_CONFIG_FRAMESTABTYPE {
OMX_U32 nSize; OMX_U32 nSize;
OMX_VERSIONTYPE nVersion; OMX_VERSIONTYPE nVersion;
OMX_U32 nPortIndex; OMX_U32 nPortIndex;
OMX_BOOL bStab; OMX_BOOL bStab;
} OMX_CONFIG_FRAMESTABTYPE; } OMX_CONFIG_FRAMESTABTYPE;
/** /**
* White Balance control type * White Balance control type
* *
* STRUCT MEMBERS: * STRUCT MEMBERS:
* SunLight : Referenced in JSR-234 * SunLight : Referenced in JSR-234
* Flash : Optimal for device's integrated flash * Flash : Optimal for device's integrated flash
*/ */
typedef enum OMX_WHITEBALCONTROLTYPE { typedef enum OMX_WHITEBALCONTROLTYPE {
OMX_WhiteBalControlOff = 0, OMX_WhiteBalControlOff = 0,
OMX_WhiteBalControlAuto, OMX_WhiteBalControlAuto,
OMX_WhiteBalControlSunLight, OMX_WhiteBalControlSunLight,
OMX_WhiteBalControlCloudy, OMX_WhiteBalControlCloudy,
OMX_WhiteBalControlShade, OMX_WhiteBalControlShade,
OMX_WhiteBalControlTungsten, OMX_WhiteBalControlTungsten,
OMX_WhiteBalControlFluorescent, OMX_WhiteBalControlFluorescent,
OMX_WhiteBalControlIncandescent, OMX_WhiteBalControlIncandescent,
OMX_WhiteBalControlFlash, OMX_WhiteBalControlFlash,
OMX_WhiteBalControlHorizon, OMX_WhiteBalControlHorizon,
OMX_WhiteBalControlKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */ OMX_WhiteBalControlKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */
OMX_WhiteBalControlVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */ OMX_WhiteBalControlVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */
OMX_WhiteBalControlMax = 0x7FFFFFFF OMX_WhiteBalControlMax = 0x7FFFFFFF
} OMX_WHITEBALCONTROLTYPE; } OMX_WHITEBALCONTROLTYPE;
/** /**
* White Balance control configuration * White Balance control configuration
* *
* STRUCT MEMBERS: * STRUCT MEMBERS:
* nSize : Size of the structure in bytes * nSize : Size of the structure in bytes
* nVersion : OMX specification version information * nVersion : OMX specification version information
* nPortIndex : Port that this structure applies to * nPortIndex : Port that this structure applies to
* eWhiteBalControl : White balance enumeration * eWhiteBalControl : White balance enumeration
*/ */
typedef struct OMX_CONFIG_WHITEBALCONTROLTYPE { typedef struct OMX_CONFIG_WHITEBALCONTROLTYPE {
OMX_U32 nSize; OMX_U32 nSize;
OMX_VERSIONTYPE nVersion; OMX_VERSIONTYPE nVersion;
OMX_U32 nPortIndex; OMX_U32 nPortIndex;
OMX_WHITEBALCONTROLTYPE eWhiteBalControl; OMX_WHITEBALCONTROLTYPE eWhiteBalControl;
} OMX_CONFIG_WHITEBALCONTROLTYPE; } OMX_CONFIG_WHITEBALCONTROLTYPE;
/** /**
* Exposure control type * Exposure control type
*/ */
typedef enum OMX_EXPOSURECONTROLTYPE { typedef enum OMX_EXPOSURECONTROLTYPE {
OMX_ExposureControlOff = 0, OMX_ExposureControlOff = 0,
OMX_ExposureControlAuto, OMX_ExposureControlAuto,
OMX_ExposureControlNight, OMX_ExposureControlNight,
OMX_ExposureControlBackLight, OMX_ExposureControlBackLight,
OMX_ExposureControlSpotLight, OMX_ExposureControlSpotLight,
OMX_ExposureControlSports, OMX_ExposureControlSports,
OMX_ExposureControlSnow, OMX_ExposureControlSnow,
OMX_ExposureControlBeach, OMX_ExposureControlBeach,
OMX_ExposureControlLargeAperture, OMX_ExposureControlLargeAperture,
OMX_ExposureControlSmallApperture, OMX_ExposureControlSmallApperture,
OMX_ExposureControlKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */ OMX_ExposureControlKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */
OMX_ExposureControlVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */ OMX_ExposureControlVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */
OMX_ExposureControlMax = 0x7FFFFFFF OMX_ExposureControlMax = 0x7FFFFFFF
} OMX_EXPOSURECONTROLTYPE; } OMX_EXPOSURECONTROLTYPE;
/** /**
* White Balance control configuration * White Balance control configuration
* *
* STRUCT MEMBERS: * STRUCT MEMBERS:
* nSize : Size of the structure in bytes * nSize : Size of the structure in bytes
* nVersion : OMX specification version information * nVersion : OMX specification version information
* nPortIndex : Port that this structure applies to * nPortIndex : Port that this structure applies to
* eExposureControl : Exposure control enumeration * eExposureControl : Exposure control enumeration
*/ */
typedef struct OMX_CONFIG_EXPOSURECONTROLTYPE { typedef struct OMX_CONFIG_EXPOSURECONTROLTYPE {
OMX_U32 nSize; OMX_U32 nSize;
OMX_VERSIONTYPE nVersion; OMX_VERSIONTYPE nVersion;
OMX_U32 nPortIndex; OMX_U32 nPortIndex;
OMX_EXPOSURECONTROLTYPE eExposureControl; OMX_EXPOSURECONTROLTYPE eExposureControl;
} OMX_CONFIG_EXPOSURECONTROLTYPE; } OMX_CONFIG_EXPOSURECONTROLTYPE;
/** /**
* Defines sensor supported mode. * Defines sensor supported mode.
* *
* STRUCT MEMBERS: * STRUCT MEMBERS:
* nSize : Size of the structure in bytes * nSize : Size of the structure in bytes
* nVersion : OMX specification version information * nVersion : OMX specification version information
* nPortIndex : Port that this structure applies to * nPortIndex : Port that this structure applies to
* nFrameRate : Single shot mode is indicated by a 0 * nFrameRate : Single shot mode is indicated by a 0
* bOneShot : Enable for single shot, disable for streaming * bOneShot : Enable for single shot, disable for streaming
* sFrameSize : Framesize * sFrameSize : Framesize
*/ */
typedef struct OMX_PARAM_SENSORMODETYPE { typedef struct OMX_PARAM_SENSORMODETYPE {
OMX_U32 nSize; OMX_U32 nSize;
OMX_VERSIONTYPE nVersion; OMX_VERSIONTYPE nVersion;
OMX_U32 nPortIndex; OMX_U32 nPortIndex;
OMX_U32 nFrameRate; OMX_U32 nFrameRate;
OMX_BOOL bOneShot; OMX_BOOL bOneShot;
OMX_FRAMESIZETYPE sFrameSize; OMX_FRAMESIZETYPE sFrameSize;
} OMX_PARAM_SENSORMODETYPE; } OMX_PARAM_SENSORMODETYPE;
/** /**
* Defines contrast level * Defines contrast level
* *
* STRUCT MEMBERS: * STRUCT MEMBERS:
* nSize : Size of the structure in bytes * nSize : Size of the structure in bytes
* nVersion : OMX specification version information * nVersion : OMX specification version information
* nPortIndex : Port that this structure applies to * nPortIndex : Port that this structure applies to
* nContrast : Values allowed for contrast -100 to 100, zero means no change * nContrast : Values allowed for contrast -100 to 100, zero means no change
*/ */
typedef struct OMX_CONFIG_CONTRASTTYPE { typedef struct OMX_CONFIG_CONTRASTTYPE {
OMX_U32 nSize; OMX_U32 nSize;
OMX_VERSIONTYPE nVersion; OMX_VERSIONTYPE nVersion;
OMX_U32 nPortIndex; OMX_U32 nPortIndex;
OMX_S32 nContrast; OMX_S32 nContrast;
} OMX_CONFIG_CONTRASTTYPE; } OMX_CONFIG_CONTRASTTYPE;
/** /**
* Defines brightness level * Defines brightness level
* *
* STRUCT MEMBERS: * STRUCT MEMBERS:
* nSize : Size of the structure in bytes * nSize : Size of the structure in bytes
* nVersion : OMX specification version information * nVersion : OMX specification version information
* nPortIndex : Port that this structure applies to * nPortIndex : Port that this structure applies to
* nBrightness : 0-100% * nBrightness : 0-100%
*/ */
typedef struct OMX_CONFIG_BRIGHTNESSTYPE { typedef struct OMX_CONFIG_BRIGHTNESSTYPE {
OMX_U32 nSize; OMX_U32 nSize;
OMX_VERSIONTYPE nVersion; OMX_VERSIONTYPE nVersion;
OMX_U32 nPortIndex; OMX_U32 nPortIndex;
OMX_U32 nBrightness; OMX_U32 nBrightness;
} OMX_CONFIG_BRIGHTNESSTYPE; } OMX_CONFIG_BRIGHTNESSTYPE;
/** /**
* Defines backlight level configuration for a video sink, e.g. LCD panel * Defines backlight level configuration for a video sink, e.g. LCD panel
* *
* STRUCT MEMBERS: * STRUCT MEMBERS:
* nSize : Size of the structure in bytes * nSize : Size of the structure in bytes
* nVersion : OMX specification version information * nVersion : OMX specification version information
* nPortIndex : Port that this structure applies to * nPortIndex : Port that this structure applies to
* nBacklight : Values allowed for backlight 0-100% * nBacklight : Values allowed for backlight 0-100%
* nTimeout : Number of milliseconds before backlight automatically turns * nTimeout : Number of milliseconds before backlight automatically turns
* off. A value of 0x0 disables backight timeout * off. A value of 0x0 disables backight timeout
*/ */
typedef struct OMX_CONFIG_BACKLIGHTTYPE { typedef struct OMX_CONFIG_BACKLIGHTTYPE {
OMX_U32 nSize; OMX_U32 nSize;
OMX_VERSIONTYPE nVersion; OMX_VERSIONTYPE nVersion;
OMX_U32 nPortIndex; OMX_U32 nPortIndex;
OMX_U32 nBacklight; OMX_U32 nBacklight;
OMX_U32 nTimeout; OMX_U32 nTimeout;
} OMX_CONFIG_BACKLIGHTTYPE; } OMX_CONFIG_BACKLIGHTTYPE;
/** /**
* Defines setting for Gamma * Defines setting for Gamma
* *
* STRUCT MEMBERS: * STRUCT MEMBERS:
* nSize : Size of the structure in bytes * nSize : Size of the structure in bytes
* nVersion : OMX specification version information * nVersion : OMX specification version information
* nPortIndex : Port that this structure applies to * nPortIndex : Port that this structure applies to
* nGamma : Values allowed for gamma -100 to 100, zero means no change * nGamma : Values allowed for gamma -100 to 100, zero means no change
*/ */
typedef struct OMX_CONFIG_GAMMATYPE { typedef struct OMX_CONFIG_GAMMATYPE {
OMX_U32 nSize; OMX_U32 nSize;
OMX_VERSIONTYPE nVersion; OMX_VERSIONTYPE nVersion;
OMX_U32 nPortIndex; OMX_U32 nPortIndex;
OMX_S32 nGamma; OMX_S32 nGamma;
} OMX_CONFIG_GAMMATYPE; } OMX_CONFIG_GAMMATYPE;
/** /**
* Define for setting saturation * Define for setting saturation
* *
* STRUCT MEMBERS: * STRUCT MEMBERS:
* nSize : Size of the structure in bytes * nSize : Size of the structure in bytes
* nVersion : OMX specification version information * nVersion : OMX specification version information
* nPortIndex : Port that this structure applies to * nPortIndex : Port that this structure applies to
* nSaturation : Values allowed for saturation -100 to 100, zero means * nSaturation : Values allowed for saturation -100 to 100, zero means
* no change * no change
*/ */
typedef struct OMX_CONFIG_SATURATIONTYPE { typedef struct OMX_CONFIG_SATURATIONTYPE {
OMX_U32 nSize; OMX_U32 nSize;
OMX_VERSIONTYPE nVersion; OMX_VERSIONTYPE nVersion;
OMX_U32 nPortIndex; OMX_U32 nPortIndex;
OMX_S32 nSaturation; OMX_S32 nSaturation;
} OMX_CONFIG_SATURATIONTYPE; } OMX_CONFIG_SATURATIONTYPE;
/** /**
* Define for setting Lightness * Define for setting Lightness
* *
* STRUCT MEMBERS: * STRUCT MEMBERS:
* nSize : Size of the structure in bytes * nSize : Size of the structure in bytes
* nVersion : OMX specification version information * nVersion : OMX specification version information
* nPortIndex : Port that this structure applies to * nPortIndex : Port that this structure applies to
* nLightness : Values allowed for lightness -100 to 100, zero means no * nLightness : Values allowed for lightness -100 to 100, zero means no
* change * change
*/ */
typedef struct OMX_CONFIG_LIGHTNESSTYPE { typedef struct OMX_CONFIG_LIGHTNESSTYPE {
OMX_U32 nSize; OMX_U32 nSize;
OMX_VERSIONTYPE nVersion; OMX_VERSIONTYPE nVersion;
OMX_U32 nPortIndex; OMX_U32 nPortIndex;
OMX_S32 nLightness; OMX_S32 nLightness;
} OMX_CONFIG_LIGHTNESSTYPE; } OMX_CONFIG_LIGHTNESSTYPE;
/** /**
* Plane blend configuration * Plane blend configuration
* *
* STRUCT MEMBERS: * STRUCT MEMBERS:
* nSize : Size of the structure in bytes * nSize : Size of the structure in bytes
* nVersion : OMX specification version information * nVersion : OMX specification version information
* nPortIndex : Index of input port associated with the plane. * nPortIndex : Index of input port associated with the plane.
* nDepth : Depth of the plane in relation to the screen. Higher * nDepth : Depth of the plane in relation to the screen. Higher
* numbered depths are "behind" lower number depths. * numbered depths are "behind" lower number depths.
* This number defaults to the Port Index number. * This number defaults to the Port Index number.
* nAlpha : Transparency blending component for the entire plane. * nAlpha : Transparency blending component for the entire plane.
* See blending modes for more detail. * See blending modes for more detail.
*/ */
typedef struct OMX_CONFIG_PLANEBLENDTYPE { typedef struct OMX_CONFIG_PLANEBLENDTYPE {
OMX_U32 nSize; OMX_U32 nSize;
OMX_VERSIONTYPE nVersion; OMX_VERSIONTYPE nVersion;
OMX_U32 nPortIndex; OMX_U32 nPortIndex;
OMX_U32 nDepth; OMX_U32 nDepth;
OMX_U32 nAlpha; OMX_U32 nAlpha;
} OMX_CONFIG_PLANEBLENDTYPE; } OMX_CONFIG_PLANEBLENDTYPE;
/** /**
* Define interlace type * Define interlace type
* *
* STRUCT MEMBERS: * STRUCT MEMBERS:
* nSize : Size of the structure in bytes * nSize : Size of the structure in bytes
* nVersion : OMX specification version information * nVersion : OMX specification version information
* nPortIndex : Port that this structure applies to * nPortIndex : Port that this structure applies to
* bEnable : Enable control variable for this functionality * bEnable : Enable control variable for this functionality
* (see below) * (see below)
* nInterleavePortIndex : Index of input or output port associated with * nInterleavePortIndex : Index of input or output port associated with
* the interleaved plane. * the interleaved plane.
* pPlanarPortIndexes[4] : Index of input or output planar ports. * pPlanarPortIndexes[4] : Index of input or output planar ports.
*/ */
typedef struct OMX_PARAM_INTERLEAVETYPE { typedef struct OMX_PARAM_INTERLEAVETYPE {
OMX_U32 nSize; OMX_U32 nSize;
OMX_VERSIONTYPE nVersion; OMX_VERSIONTYPE nVersion;
OMX_U32 nPortIndex; OMX_U32 nPortIndex;
OMX_BOOL bEnable; OMX_BOOL bEnable;
OMX_U32 nInterleavePortIndex; OMX_U32 nInterleavePortIndex;
} OMX_PARAM_INTERLEAVETYPE; } OMX_PARAM_INTERLEAVETYPE;
/** /**
* Defines the picture effect used for an input picture * Defines the picture effect used for an input picture
*/ */
typedef enum OMX_TRANSITIONEFFECTTYPE { typedef enum OMX_TRANSITIONEFFECTTYPE {
OMX_EffectNone, OMX_EffectNone,
OMX_EffectFadeFromBlack, OMX_EffectFadeFromBlack,
OMX_EffectFadeToBlack, OMX_EffectFadeToBlack,
OMX_EffectUnspecifiedThroughConstantColor, OMX_EffectUnspecifiedThroughConstantColor,
OMX_EffectDissolve, OMX_EffectDissolve,
OMX_EffectWipe, OMX_EffectWipe,
OMX_EffectUnspecifiedMixOfTwoScenes, OMX_EffectUnspecifiedMixOfTwoScenes,
OMX_EffectKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */ OMX_EffectKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */
OMX_EffectVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */ OMX_EffectVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */
OMX_EffectMax = 0x7FFFFFFF OMX_EffectMax = 0x7FFFFFFF
} OMX_TRANSITIONEFFECTTYPE; } OMX_TRANSITIONEFFECTTYPE;
/** /**
* Structure used to configure current transition effect * Structure used to configure current transition effect
* *
* STRUCT MEMBERS: * STRUCT MEMBERS:
* nSize : Size of the structure in bytes * nSize : Size of the structure in bytes
* nVersion : OMX specification version information * nVersion : OMX specification version information
* nPortIndex : Port that this structure applies to * nPortIndex : Port that this structure applies to
* eEffect : Effect to enable * eEffect : Effect to enable
*/ */
typedef struct OMX_CONFIG_TRANSITIONEFFECTTYPE { typedef struct OMX_CONFIG_TRANSITIONEFFECTTYPE {
OMX_U32 nSize; OMX_U32 nSize;
OMX_VERSIONTYPE nVersion; OMX_VERSIONTYPE nVersion;
OMX_U32 nPortIndex; OMX_U32 nPortIndex;
OMX_TRANSITIONEFFECTTYPE eEffect; OMX_TRANSITIONEFFECTTYPE eEffect;
} OMX_CONFIG_TRANSITIONEFFECTTYPE; } OMX_CONFIG_TRANSITIONEFFECTTYPE;
/** /**
* Defines possible data unit types for encoded video data. The data unit * Defines possible data unit types for encoded video data. The data unit
* types are used both for encoded video input for playback as well as * types are used both for encoded video input for playback as well as
* encoded video output from recording. * encoded video output from recording.
*/ */
typedef enum OMX_DATAUNITTYPE { typedef enum OMX_DATAUNITTYPE {
OMX_DataUnitCodedPicture, OMX_DataUnitCodedPicture,
OMX_DataUnitVideoSegment, OMX_DataUnitVideoSegment,
OMX_DataUnitSeveralSegments, OMX_DataUnitSeveralSegments,
OMX_DataUnitArbitraryStreamSection, OMX_DataUnitArbitraryStreamSection,
OMX_DataUnitKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */ OMX_DataUnitKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */
OMX_DataUnitVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */ OMX_DataUnitVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */
OMX_DataUnitMax = 0x7FFFFFFF OMX_DataUnitMax = 0x7FFFFFFF
} OMX_DATAUNITTYPE; } OMX_DATAUNITTYPE;
/** /**
* Defines possible encapsulation types for coded video data unit. The * Defines possible encapsulation types for coded video data unit. The
* encapsulation information is used both for encoded video input for * encapsulation information is used both for encoded video input for
* playback as well as encoded video output from recording. * playback as well as encoded video output from recording.
*/ */
typedef enum OMX_DATAUNITENCAPSULATIONTYPE { typedef enum OMX_DATAUNITENCAPSULATIONTYPE {
OMX_DataEncapsulationElementaryStream, OMX_DataEncapsulationElementaryStream,
OMX_DataEncapsulationGenericPayload, OMX_DataEncapsulationGenericPayload,
OMX_DataEncapsulationRtpPayload, OMX_DataEncapsulationRtpPayload,
OMX_DataEncapsulationKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */ OMX_DataEncapsulationKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */
OMX_DataEncapsulationVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */ OMX_DataEncapsulationVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */
OMX_DataEncapsulationMax = 0x7FFFFFFF OMX_DataEncapsulationMax = 0x7FFFFFFF
} OMX_DATAUNITENCAPSULATIONTYPE; } OMX_DATAUNITENCAPSULATIONTYPE;
/** /**
* Structure used to configure the type of being decoded/encoded * Structure used to configure the type of being decoded/encoded
*/ */
typedef struct OMX_PARAM_DATAUNITTYPE { typedef struct OMX_PARAM_DATAUNITTYPE {
OMX_U32 nSize; /**< Size of the structure in bytes */ OMX_U32 nSize; /**< Size of the structure in bytes */
OMX_VERSIONTYPE nVersion; /**< OMX specification version information */ OMX_VERSIONTYPE nVersion; /**< OMX specification version information */
OMX_U32 nPortIndex; /**< Port that this structure applies to */ OMX_U32 nPortIndex; /**< Port that this structure applies to */
OMX_DATAUNITTYPE eUnitType; OMX_DATAUNITTYPE eUnitType;
OMX_DATAUNITENCAPSULATIONTYPE eEncapsulationType; OMX_DATAUNITENCAPSULATIONTYPE eEncapsulationType;
} OMX_PARAM_DATAUNITTYPE; } OMX_PARAM_DATAUNITTYPE;
/** /**
* Defines dither types * Defines dither types
*/ */
typedef enum OMX_DITHERTYPE { typedef enum OMX_DITHERTYPE {
OMX_DitherNone, OMX_DitherNone,
OMX_DitherOrdered, OMX_DitherOrdered,
OMX_DitherErrorDiffusion, OMX_DitherErrorDiffusion,
OMX_DitherOther, OMX_DitherOther,
OMX_DitherKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */ OMX_DitherKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */
OMX_DitherVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */ OMX_DitherVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */
OMX_DitherMax = 0x7FFFFFFF OMX_DitherMax = 0x7FFFFFFF
} OMX_DITHERTYPE; } OMX_DITHERTYPE;
/** /**
* Structure used to configure current type of dithering * Structure used to configure current type of dithering
*/ */
typedef struct OMX_CONFIG_DITHERTYPE { typedef struct OMX_CONFIG_DITHERTYPE {
OMX_U32 nSize; /**< Size of the structure in bytes */ OMX_U32 nSize; /**< Size of the structure in bytes */
OMX_VERSIONTYPE nVersion; /**< OMX specification version information */ OMX_VERSIONTYPE nVersion; /**< OMX specification version information */
OMX_U32 nPortIndex; /**< Port that this structure applies to */ OMX_U32 nPortIndex; /**< Port that this structure applies to */
OMX_DITHERTYPE eDither; /**< Type of dithering to use */ OMX_DITHERTYPE eDither; /**< Type of dithering to use */
} OMX_CONFIG_DITHERTYPE; } OMX_CONFIG_DITHERTYPE;
typedef struct OMX_CONFIG_CAPTUREMODETYPE { typedef struct OMX_CONFIG_CAPTUREMODETYPE {
OMX_U32 nSize; OMX_U32 nSize;
OMX_VERSIONTYPE nVersion; OMX_VERSIONTYPE nVersion;
OMX_U32 nPortIndex; /**< Port that this structure applies to */ OMX_U32 nPortIndex; /**< Port that this structure applies to */
OMX_BOOL bContinuous; /**< If true then ignore frame rate and emit capture OMX_BOOL bContinuous; /**< If true then ignore frame rate and emit capture
* data as fast as possible (otherwise obey port's frame rate). */ * data as fast as possible (otherwise obey port's frame rate). */
OMX_BOOL bFrameLimited; /**< If true then terminate capture after the port emits the OMX_BOOL bFrameLimited; /**< If true then terminate capture after the port emits the
* specified number of frames (otherwise the port does not * specified number of frames (otherwise the port does not
* terminate the capture until instructed to do so by the client). * terminate the capture until instructed to do so by the client).
* Even if set, the client may manually terminate the capture prior * Even if set, the client may manually terminate the capture prior
* to reaching the limit. */ * to reaching the limit. */
OMX_U32 nFrameLimit; /**< Limit on number of frames emitted during a capture (only OMX_U32 nFrameLimit; /**< Limit on number of frames emitted during a capture (only
* valid if bFrameLimited is set). */ * valid if bFrameLimited is set). */
} OMX_CONFIG_CAPTUREMODETYPE; } OMX_CONFIG_CAPTUREMODETYPE;
typedef enum OMX_METERINGTYPE { typedef enum OMX_METERINGTYPE {
OMX_MeteringModeAverage, /**< Center-weighted average metering. */ OMX_MeteringModeAverage, /**< Center-weighted average metering. */
OMX_MeteringModeSpot, /**< Spot (partial) metering. */ OMX_MeteringModeSpot, /**< Spot (partial) metering. */
OMX_MeteringModeMatrix, /**< Matrix or evaluative metering. */ OMX_MeteringModeMatrix, /**< Matrix or evaluative metering. */
OMX_MeteringKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */ OMX_MeteringKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */
OMX_MeteringVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */ OMX_MeteringVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */
OMX_EVModeMax = 0x7fffffff OMX_EVModeMax = 0x7fffffff
} OMX_METERINGTYPE; } OMX_METERINGTYPE;
typedef struct OMX_CONFIG_EXPOSUREVALUETYPE { typedef struct OMX_CONFIG_EXPOSUREVALUETYPE {
OMX_U32 nSize; OMX_U32 nSize;
OMX_VERSIONTYPE nVersion; OMX_VERSIONTYPE nVersion;
OMX_U32 nPortIndex; OMX_U32 nPortIndex;
OMX_METERINGTYPE eMetering; OMX_METERINGTYPE eMetering;
OMX_S32 xEVCompensation; /**< Fixed point value stored as Q16 */ OMX_S32 xEVCompensation; /**< Fixed point value stored as Q16 */
OMX_U32 nApertureFNumber; /**< e.g. nApertureFNumber = 2 implies "f/2" - Q16 format */ OMX_U32 nApertureFNumber; /**< e.g. nApertureFNumber = 2 implies "f/2" - Q16 format */
OMX_BOOL bAutoAperture; /**< Whether aperture number is defined automatically */ OMX_BOOL bAutoAperture; /**< Whether aperture number is defined automatically */
OMX_U32 nShutterSpeedMsec; /**< Shutterspeed in milliseconds */ OMX_U32 nShutterSpeedMsec; /**< Shutterspeed in milliseconds */
OMX_BOOL bAutoShutterSpeed; /**< Whether shutter speed is defined automatically */ OMX_BOOL bAutoShutterSpeed; /**< Whether shutter speed is defined automatically */
OMX_U32 nSensitivity; /**< e.g. nSensitivity = 100 implies "ISO 100" */ OMX_U32 nSensitivity; /**< e.g. nSensitivity = 100 implies "ISO 100" */
OMX_BOOL bAutoSensitivity; /**< Whether sensitivity is defined automatically */ OMX_BOOL bAutoSensitivity; /**< Whether sensitivity is defined automatically */
} OMX_CONFIG_EXPOSUREVALUETYPE; } OMX_CONFIG_EXPOSUREVALUETYPE;
/** /**
* Focus region configuration * Focus region configuration
* *
* STRUCT MEMBERS: * STRUCT MEMBERS:
* nSize : Size of the structure in bytes * nSize : Size of the structure in bytes
* nVersion : OMX specification version information * nVersion : OMX specification version information
* nPortIndex : Port that this structure applies to * nPortIndex : Port that this structure applies to
* bCenter : Use center region as focus region of interest * bCenter : Use center region as focus region of interest
* bLeft : Use left region as focus region of interest * bLeft : Use left region as focus region of interest
* bRight : Use right region as focus region of interest * bRight : Use right region as focus region of interest
* bTop : Use top region as focus region of interest * bTop : Use top region as focus region of interest
* bBottom : Use bottom region as focus region of interest * bBottom : Use bottom region as focus region of interest
* bTopLeft : Use top left region as focus region of interest * bTopLeft : Use top left region as focus region of interest
* bTopRight : Use top right region as focus region of interest * bTopRight : Use top right region as focus region of interest
* bBottomLeft : Use bottom left region as focus region of interest * bBottomLeft : Use bottom left region as focus region of interest
* bBottomRight : Use bottom right region as focus region of interest * bBottomRight : Use bottom right region as focus region of interest
*/ */
typedef struct OMX_CONFIG_FOCUSREGIONTYPE { typedef struct OMX_CONFIG_FOCUSREGIONTYPE {
OMX_U32 nSize; OMX_U32 nSize;
OMX_VERSIONTYPE nVersion; OMX_VERSIONTYPE nVersion;
OMX_U32 nPortIndex; OMX_U32 nPortIndex;
OMX_BOOL bCenter; OMX_BOOL bCenter;
OMX_BOOL bLeft; OMX_BOOL bLeft;
OMX_BOOL bRight; OMX_BOOL bRight;
OMX_BOOL bTop; OMX_BOOL bTop;
OMX_BOOL bBottom; OMX_BOOL bBottom;
OMX_BOOL bTopLeft; OMX_BOOL bTopLeft;
OMX_BOOL bTopRight; OMX_BOOL bTopRight;
OMX_BOOL bBottomLeft; OMX_BOOL bBottomLeft;
OMX_BOOL bBottomRight; OMX_BOOL bBottomRight;
} OMX_CONFIG_FOCUSREGIONTYPE; } OMX_CONFIG_FOCUSREGIONTYPE;
/** /**
* Focus Status type * Focus Status type
*/ */
typedef enum OMX_FOCUSSTATUSTYPE { typedef enum OMX_FOCUSSTATUSTYPE {
OMX_FocusStatusOff = 0, OMX_FocusStatusOff = 0,
OMX_FocusStatusRequest, OMX_FocusStatusRequest,
OMX_FocusStatusReached, OMX_FocusStatusReached,
OMX_FocusStatusUnableToReach, OMX_FocusStatusUnableToReach,
OMX_FocusStatusLost, OMX_FocusStatusLost,
OMX_FocusStatusKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */ OMX_FocusStatusKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */
OMX_FocusStatusVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */ OMX_FocusStatusVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */
OMX_FocusStatusMax = 0x7FFFFFFF OMX_FocusStatusMax = 0x7FFFFFFF
} OMX_FOCUSSTATUSTYPE; } OMX_FOCUSSTATUSTYPE;
/** /**
* Focus status configuration * Focus status configuration
* *
* STRUCT MEMBERS: * STRUCT MEMBERS:
* nSize : Size of the structure in bytes * nSize : Size of the structure in bytes
* nVersion : OMX specification version information * nVersion : OMX specification version information
* nPortIndex : Port that this structure applies to * nPortIndex : Port that this structure applies to
* eFocusStatus : Specifies the focus status * eFocusStatus : Specifies the focus status
* bCenterStatus : Use center region as focus region of interest * bCenterStatus : Use center region as focus region of interest
* bLeftStatus : Use left region as focus region of interest * bLeftStatus : Use left region as focus region of interest
* bRightStatus : Use right region as focus region of interest * bRightStatus : Use right region as focus region of interest
* bTopStatus : Use top region as focus region of interest * bTopStatus : Use top region as focus region of interest
* bBottomStatus : Use bottom region as focus region of interest * bBottomStatus : Use bottom region as focus region of interest
* bTopLeftStatus : Use top left region as focus region of interest * bTopLeftStatus : Use top left region as focus region of interest
* bTopRightStatus : Use top right region as focus region of interest * bTopRightStatus : Use top right region as focus region of interest
* bBottomLeftStatus : Use bottom left region as focus region of interest * bBottomLeftStatus : Use bottom left region as focus region of interest
* bBottomRightStatus : Use bottom right region as focus region of interest * bBottomRightStatus : Use bottom right region as focus region of interest
*/ */
typedef struct OMX_PARAM_FOCUSSTATUSTYPE { typedef struct OMX_PARAM_FOCUSSTATUSTYPE {
OMX_U32 nSize; OMX_U32 nSize;
OMX_VERSIONTYPE nVersion; OMX_VERSIONTYPE nVersion;
OMX_U32 nPortIndex; OMX_U32 nPortIndex;
OMX_FOCUSSTATUSTYPE eFocusStatus; OMX_FOCUSSTATUSTYPE eFocusStatus;
OMX_BOOL bCenterStatus; OMX_BOOL bCenterStatus;
OMX_BOOL bLeftStatus; OMX_BOOL bLeftStatus;
OMX_BOOL bRightStatus; OMX_BOOL bRightStatus;
OMX_BOOL bTopStatus; OMX_BOOL bTopStatus;
OMX_BOOL bBottomStatus; OMX_BOOL bBottomStatus;
OMX_BOOL bTopLeftStatus; OMX_BOOL bTopLeftStatus;
OMX_BOOL bTopRightStatus; OMX_BOOL bTopRightStatus;
OMX_BOOL bBottomLeftStatus; OMX_BOOL bBottomLeftStatus;
OMX_BOOL bBottomRightStatus; OMX_BOOL bBottomRightStatus;
} OMX_PARAM_FOCUSSTATUSTYPE; } OMX_PARAM_FOCUSSTATUSTYPE;
/** @} */ /** @} */
#ifdef __cplusplus #ifdef __cplusplus
} }
#endif /* __cplusplus */ #endif /* __cplusplus */
#endif #endif
/* File EOF */ /* File EOF */
/** /**
* Copyright (c) 2008 The Khronos Group Inc. * Copyright (c) 2008 The Khronos Group Inc.
* *
* Permission is hereby granted, free of charge, to any person obtaining * Permission is hereby granted, free of charge, to any person obtaining
* a copy of this software and associated documentation files (the * a copy of this software and associated documentation files (the
* "Software"), to deal in the Software without restriction, including * "Software"), to deal in the Software without restriction, including
* without limitation the rights to use, copy, modify, merge, publish, * without limitation the rights to use, copy, modify, merge, publish,
* distribute, sublicense, and/or sell copies of the Software, and to * distribute, sublicense, and/or sell copies of the Software, and to
* permit persons to whom the Software is furnished to do so, subject * permit persons to whom the Software is furnished to do so, subject
* to the following conditions: * to the following conditions:
* The above copyright notice and this permission notice shall be included * The above copyright notice and this permission notice shall be included
* in all copies or substantial portions of the Software. * in all copies or substantial portions of the Software.
* *
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
* OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, * CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
*/ */
/** /**
* @file OMX_Image.h - OpenMax IL version 1.1.2 * @file OMX_Image.h - OpenMax IL version 1.1.2
* The structures needed by Image components to exchange parameters and * The structures needed by Image components to exchange parameters and
* configuration data with the components. * configuration data with the components.
*/ */
#ifndef OMX_Image_h #ifndef OMX_Image_h
#define OMX_Image_h #define OMX_Image_h
#ifdef __cplusplus #ifdef __cplusplus
extern "C" { extern "C" {
#endif /* __cplusplus */ #endif /* __cplusplus */
/** /**
* Each OMX header must include all required header files to allow the * Each OMX header must include all required header files to allow the
* header to compile without errors. The includes below are required * header to compile without errors. The includes below are required
* for this header file to compile successfully * for this header file to compile successfully
*/ */
#include <OMX_IVCommon.h> #include <OMX_IVCommon.h>
/** @defgroup imaging OpenMAX IL Imaging Domain /** @defgroup imaging OpenMAX IL Imaging Domain
* @ingroup iv * @ingroup iv
* Structures for OpenMAX IL Imaging domain * Structures for OpenMAX IL Imaging domain
* @{ * @{
*/ */
/** /**
* Enumeration used to define the possible image compression coding. * Enumeration used to define the possible image compression coding.
*/ */
typedef enum OMX_IMAGE_CODINGTYPE { typedef enum OMX_IMAGE_CODINGTYPE {
OMX_IMAGE_CodingUnused, /**< Value when format is N/A */ OMX_IMAGE_CodingUnused, /**< Value when format is N/A */
OMX_IMAGE_CodingAutoDetect, /**< Auto detection of image format */ OMX_IMAGE_CodingAutoDetect, /**< Auto detection of image format */
OMX_IMAGE_CodingJPEG, /**< JPEG/JFIF image format */ OMX_IMAGE_CodingJPEG, /**< JPEG/JFIF image format */
OMX_IMAGE_CodingJPEG2K, /**< JPEG 2000 image format */ OMX_IMAGE_CodingJPEG2K, /**< JPEG 2000 image format */
OMX_IMAGE_CodingEXIF, /**< EXIF image format */ OMX_IMAGE_CodingEXIF, /**< EXIF image format */
OMX_IMAGE_CodingTIFF, /**< TIFF image format */ OMX_IMAGE_CodingTIFF, /**< TIFF image format */
OMX_IMAGE_CodingGIF, /**< Graphics image format */ OMX_IMAGE_CodingGIF, /**< Graphics image format */
OMX_IMAGE_CodingPNG, /**< PNG image format */ OMX_IMAGE_CodingPNG, /**< PNG image format */
OMX_IMAGE_CodingLZW, /**< LZW image format */ OMX_IMAGE_CodingLZW, /**< LZW image format */
OMX_IMAGE_CodingBMP, /**< Windows Bitmap format */ OMX_IMAGE_CodingBMP, /**< Windows Bitmap format */
OMX_IMAGE_CodingKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */ OMX_IMAGE_CodingKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */
OMX_IMAGE_CodingVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */ OMX_IMAGE_CodingVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */
OMX_IMAGE_CodingMax = 0x7FFFFFFF OMX_IMAGE_CodingMax = 0x7FFFFFFF
} OMX_IMAGE_CODINGTYPE; } OMX_IMAGE_CODINGTYPE;
/** /**
* Data structure used to define an image path. The number of image paths * Data structure used to define an image path. The number of image paths
* for input and output will vary by type of the image component. * for input and output will vary by type of the image component.
* *
* Input (aka Source) : Zero Inputs, one Output, * Input (aka Source) : Zero Inputs, one Output,
* Splitter : One Input, 2 or more Outputs, * Splitter : One Input, 2 or more Outputs,
* Processing Element : One Input, one output, * Processing Element : One Input, one output,
* Mixer : 2 or more inputs, one output, * Mixer : 2 or more inputs, one output,
* Output (aka Sink) : One Input, zero outputs. * Output (aka Sink) : One Input, zero outputs.
* *
* The PortDefinition structure is used to define all of the parameters * The PortDefinition structure is used to define all of the parameters
* necessary for the compliant component to setup an input or an output * necessary for the compliant component to setup an input or an output
* image path. If additional vendor specific data is required, it should * image path. If additional vendor specific data is required, it should
* be transmitted to the component using the CustomCommand function. * be transmitted to the component using the CustomCommand function.
* Compliant components will prepopulate this structure with optimal * Compliant components will prepopulate this structure with optimal
* values during the OMX_GetParameter() command. * values during the OMX_GetParameter() command.
* *
* STRUCT MEMBERS: * STRUCT MEMBERS:
* cMIMEType : MIME type of data for the port * cMIMEType : MIME type of data for the port
* pNativeRender : Platform specific reference for a display if a * pNativeRender : Platform specific reference for a display if a
* sync, otherwise this field is 0 * sync, otherwise this field is 0
* nFrameWidth : Width of frame to be used on port if * nFrameWidth : Width of frame to be used on port if
* uncompressed format is used. Use 0 for * uncompressed format is used. Use 0 for
* unknown, don't care or variable * unknown, don't care or variable
* nFrameHeight : Height of frame to be used on port if * nFrameHeight : Height of frame to be used on port if
* uncompressed format is used. Use 0 for * uncompressed format is used. Use 0 for
* unknown, don't care or variable * unknown, don't care or variable
* nStride : Number of bytes per span of an image (i.e. * nStride : Number of bytes per span of an image (i.e.
* indicates the number of bytes to get from * indicates the number of bytes to get from
* span N to span N+1, where negative stride * span N to span N+1, where negative stride
* indicates the image is bottom up * indicates the image is bottom up
* nSliceHeight : Height used when encoding in slices * nSliceHeight : Height used when encoding in slices
* bFlagErrorConcealment : Turns on error concealment if it is supported by * bFlagErrorConcealment : Turns on error concealment if it is supported by
* the OMX component * the OMX component
* eCompressionFormat : Compression format used in this instance of * eCompressionFormat : Compression format used in this instance of
* the component. When OMX_IMAGE_CodingUnused is * the component. When OMX_IMAGE_CodingUnused is
* specified, eColorFormat is valid * specified, eColorFormat is valid
* eColorFormat : Decompressed format used by this component * eColorFormat : Decompressed format used by this component
* pNativeWindow : Platform specific reference for a window object if a * pNativeWindow : Platform specific reference for a window object if a
* display sink , otherwise this field is 0x0. * display sink , otherwise this field is 0x0.
*/ */
typedef struct OMX_IMAGE_PORTDEFINITIONTYPE { typedef struct OMX_IMAGE_PORTDEFINITIONTYPE {
OMX_STRING cMIMEType; OMX_STRING cMIMEType;
OMX_NATIVE_DEVICETYPE pNativeRender; OMX_NATIVE_DEVICETYPE pNativeRender;
OMX_U32 nFrameWidth; OMX_U32 nFrameWidth;
OMX_U32 nFrameHeight; OMX_U32 nFrameHeight;
OMX_S32 nStride; OMX_S32 nStride;
OMX_U32 nSliceHeight; OMX_U32 nSliceHeight;
OMX_BOOL bFlagErrorConcealment; OMX_BOOL bFlagErrorConcealment;
OMX_IMAGE_CODINGTYPE eCompressionFormat; OMX_IMAGE_CODINGTYPE eCompressionFormat;
OMX_COLOR_FORMATTYPE eColorFormat; OMX_COLOR_FORMATTYPE eColorFormat;
OMX_NATIVE_WINDOWTYPE pNativeWindow; OMX_NATIVE_WINDOWTYPE pNativeWindow;
} OMX_IMAGE_PORTDEFINITIONTYPE; } OMX_IMAGE_PORTDEFINITIONTYPE;
/** /**
* Port format parameter. This structure is used to enumerate the various * Port format parameter. This structure is used to enumerate the various
* data input/output format supported by the port. * data input/output format supported by the port.
* *
* STRUCT MEMBERS: * STRUCT MEMBERS:
* nSize : Size of the structure in bytes * nSize : Size of the structure in bytes
* nVersion : OMX specification version information * nVersion : OMX specification version information
* nPortIndex : Indicates which port to set * nPortIndex : Indicates which port to set
* nIndex : Indicates the enumeration index for the format from * nIndex : Indicates the enumeration index for the format from
* 0x0 to N-1 * 0x0 to N-1
* eCompressionFormat : Compression format used in this instance of the * eCompressionFormat : Compression format used in this instance of the
* component. When OMX_IMAGE_CodingUnused is specified, * component. When OMX_IMAGE_CodingUnused is specified,
* eColorFormat is valid * eColorFormat is valid
* eColorFormat : Decompressed format used by this component * eColorFormat : Decompressed format used by this component
*/ */
typedef struct OMX_IMAGE_PARAM_PORTFORMATTYPE { typedef struct OMX_IMAGE_PARAM_PORTFORMATTYPE {
OMX_U32 nSize; OMX_U32 nSize;
OMX_VERSIONTYPE nVersion; OMX_VERSIONTYPE nVersion;
OMX_U32 nPortIndex; OMX_U32 nPortIndex;
OMX_U32 nIndex; OMX_U32 nIndex;
OMX_IMAGE_CODINGTYPE eCompressionFormat; OMX_IMAGE_CODINGTYPE eCompressionFormat;
OMX_COLOR_FORMATTYPE eColorFormat; OMX_COLOR_FORMATTYPE eColorFormat;
} OMX_IMAGE_PARAM_PORTFORMATTYPE; } OMX_IMAGE_PARAM_PORTFORMATTYPE;
/** /**
* Flash control type * Flash control type
* *
* ENUMS * ENUMS
* Torch : Flash forced constantly on * Torch : Flash forced constantly on
*/ */
typedef enum OMX_IMAGE_FLASHCONTROLTYPE { typedef enum OMX_IMAGE_FLASHCONTROLTYPE {
OMX_IMAGE_FlashControlOn = 0, OMX_IMAGE_FlashControlOn = 0,
OMX_IMAGE_FlashControlOff, OMX_IMAGE_FlashControlOff,
OMX_IMAGE_FlashControlAuto, OMX_IMAGE_FlashControlAuto,
OMX_IMAGE_FlashControlRedEyeReduction, OMX_IMAGE_FlashControlRedEyeReduction,
OMX_IMAGE_FlashControlFillin, OMX_IMAGE_FlashControlFillin,
OMX_IMAGE_FlashControlTorch, OMX_IMAGE_FlashControlTorch,
OMX_IMAGE_FlashControlKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */ OMX_IMAGE_FlashControlKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */
OMX_IMAGE_FlashControlVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */ OMX_IMAGE_FlashControlVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */
OMX_IMAGE_FlashControlMax = 0x7FFFFFFF OMX_IMAGE_FlashControlMax = 0x7FFFFFFF
} OMX_IMAGE_FLASHCONTROLTYPE; } OMX_IMAGE_FLASHCONTROLTYPE;
/** /**
* Flash control configuration * Flash control configuration
* *
* STRUCT MEMBERS: * STRUCT MEMBERS:
* nSize : Size of the structure in bytes * nSize : Size of the structure in bytes
* nVersion : OMX specification version information * nVersion : OMX specification version information
* nPortIndex : Port that this structure applies to * nPortIndex : Port that this structure applies to
* eFlashControl : Flash control type * eFlashControl : Flash control type
*/ */
typedef struct OMX_IMAGE_PARAM_FLASHCONTROLTYPE { typedef struct OMX_IMAGE_PARAM_FLASHCONTROLTYPE {
OMX_U32 nSize; OMX_U32 nSize;
OMX_VERSIONTYPE nVersion; OMX_VERSIONTYPE nVersion;
OMX_U32 nPortIndex; OMX_U32 nPortIndex;
OMX_IMAGE_FLASHCONTROLTYPE eFlashControl; OMX_IMAGE_FLASHCONTROLTYPE eFlashControl;
} OMX_IMAGE_PARAM_FLASHCONTROLTYPE; } OMX_IMAGE_PARAM_FLASHCONTROLTYPE;
/** /**
* Focus control type * Focus control type
*/ */
typedef enum OMX_IMAGE_FOCUSCONTROLTYPE { typedef enum OMX_IMAGE_FOCUSCONTROLTYPE {
OMX_IMAGE_FocusControlOn = 0, OMX_IMAGE_FocusControlOn = 0,
OMX_IMAGE_FocusControlOff, OMX_IMAGE_FocusControlOff,
OMX_IMAGE_FocusControlAuto, OMX_IMAGE_FocusControlAuto,
OMX_IMAGE_FocusControlAutoLock, OMX_IMAGE_FocusControlAutoLock,
OMX_IMAGE_FocusControlKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */ OMX_IMAGE_FocusControlKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */
OMX_IMAGE_FocusControlVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */ OMX_IMAGE_FocusControlVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */
OMX_IMAGE_FocusControlMax = 0x7FFFFFFF OMX_IMAGE_FocusControlMax = 0x7FFFFFFF
} OMX_IMAGE_FOCUSCONTROLTYPE; } OMX_IMAGE_FOCUSCONTROLTYPE;
/** /**
* Focus control configuration * Focus control configuration
* *
* STRUCT MEMBERS: * STRUCT MEMBERS:
* nSize : Size of the structure in bytes * nSize : Size of the structure in bytes
* nVersion : OMX specification version information * nVersion : OMX specification version information
* nPortIndex : Port that this structure applies to * nPortIndex : Port that this structure applies to
* eFocusControl : Focus control * eFocusControl : Focus control
* nFocusSteps : Focus can take on values from 0 mm to infinity. * nFocusSteps : Focus can take on values from 0 mm to infinity.
* Interest is only in number of steps over this range. * Interest is only in number of steps over this range.
* nFocusStepIndex : Current focus step index * nFocusStepIndex : Current focus step index
*/ */
typedef struct OMX_IMAGE_CONFIG_FOCUSCONTROLTYPE { typedef struct OMX_IMAGE_CONFIG_FOCUSCONTROLTYPE {
OMX_U32 nSize; OMX_U32 nSize;
OMX_VERSIONTYPE nVersion; OMX_VERSIONTYPE nVersion;
OMX_U32 nPortIndex; OMX_U32 nPortIndex;
OMX_IMAGE_FOCUSCONTROLTYPE eFocusControl; OMX_IMAGE_FOCUSCONTROLTYPE eFocusControl;
OMX_U32 nFocusSteps; OMX_U32 nFocusSteps;
OMX_U32 nFocusStepIndex; OMX_U32 nFocusStepIndex;
} OMX_IMAGE_CONFIG_FOCUSCONTROLTYPE; } OMX_IMAGE_CONFIG_FOCUSCONTROLTYPE;
/** /**
* Q Factor for JPEG compression, which controls the tradeoff between image * Q Factor for JPEG compression, which controls the tradeoff between image
* quality and size. Q Factor provides a more simple means of controlling * quality and size. Q Factor provides a more simple means of controlling
* JPEG compression quality, without directly programming Quantization * JPEG compression quality, without directly programming Quantization
* tables for chroma and luma * tables for chroma and luma
* *
* STRUCT MEMBERS: * STRUCT MEMBERS:
* nSize : Size of the structure in bytes * nSize : Size of the structure in bytes
* nVersion : OMX specification version information * nVersion : OMX specification version information
* nPortIndex : Port that this structure applies to * nPortIndex : Port that this structure applies to
* nQFactor : JPEG Q factor value in the range of 1-100. A factor of 1 * nQFactor : JPEG Q factor value in the range of 1-100. A factor of 1
* produces the smallest, worst quality images, and a factor * produces the smallest, worst quality images, and a factor
* of 100 produces the largest, best quality images. A * of 100 produces the largest, best quality images. A
* typical default is 75 for small good quality images * typical default is 75 for small good quality images
*/ */
typedef struct OMX_IMAGE_PARAM_QFACTORTYPE { typedef struct OMX_IMAGE_PARAM_QFACTORTYPE {
OMX_U32 nSize; OMX_U32 nSize;
OMX_VERSIONTYPE nVersion; OMX_VERSIONTYPE nVersion;
OMX_U32 nPortIndex; OMX_U32 nPortIndex;
OMX_U32 nQFactor; OMX_U32 nQFactor;
} OMX_IMAGE_PARAM_QFACTORTYPE; } OMX_IMAGE_PARAM_QFACTORTYPE;
/** /**
* Quantization table type * Quantization table type
*/ */
typedef enum OMX_IMAGE_QUANTIZATIONTABLETYPE { typedef enum OMX_IMAGE_QUANTIZATIONTABLETYPE {
OMX_IMAGE_QuantizationTableLuma = 0, OMX_IMAGE_QuantizationTableLuma = 0,
OMX_IMAGE_QuantizationTableChroma, OMX_IMAGE_QuantizationTableChroma,
OMX_IMAGE_QuantizationTableChromaCb, OMX_IMAGE_QuantizationTableChromaCb,
OMX_IMAGE_QuantizationTableChromaCr, OMX_IMAGE_QuantizationTableChromaCr,
OMX_IMAGE_QuantizationTableKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */ OMX_IMAGE_QuantizationTableKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */
OMX_IMAGE_QuantizationTableVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */ OMX_IMAGE_QuantizationTableVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */
OMX_IMAGE_QuantizationTableMax = 0x7FFFFFFF OMX_IMAGE_QuantizationTableMax = 0x7FFFFFFF
} OMX_IMAGE_QUANTIZATIONTABLETYPE; } OMX_IMAGE_QUANTIZATIONTABLETYPE;
/** /**
* JPEG quantization tables are used to determine DCT compression for * JPEG quantization tables are used to determine DCT compression for
* YUV data, as an alternative to specifying Q factor, providing exact * YUV data, as an alternative to specifying Q factor, providing exact
* control of compression * control of compression
* *
* STRUCT MEMBERS: * STRUCT MEMBERS:
* nSize : Size of the structure in bytes * nSize : Size of the structure in bytes
* nVersion : OMX specification version information * nVersion : OMX specification version information
* nPortIndex : Port that this structure applies to * nPortIndex : Port that this structure applies to
* eQuantizationTable : Quantization table type * eQuantizationTable : Quantization table type
* nQuantizationMatrix[64] : JPEG quantization table of coefficients stored * nQuantizationMatrix[64] : JPEG quantization table of coefficients stored
* in increasing columns then by rows of data (i.e. * in increasing columns then by rows of data (i.e.
* row 1, ... row 8). Quantization values are in * row 1, ... row 8). Quantization values are in
* the range 0-255 and stored in linear order * the range 0-255 and stored in linear order
* (i.e. the component will zig-zag the * (i.e. the component will zig-zag the
* quantization table data if required internally) * quantization table data if required internally)
*/ */
typedef struct OMX_IMAGE_PARAM_QUANTIZATIONTABLETYPE { typedef struct OMX_IMAGE_PARAM_QUANTIZATIONTABLETYPE {
OMX_U32 nSize; OMX_U32 nSize;
OMX_VERSIONTYPE nVersion; OMX_VERSIONTYPE nVersion;
OMX_U32 nPortIndex; OMX_U32 nPortIndex;
OMX_IMAGE_QUANTIZATIONTABLETYPE eQuantizationTable; OMX_IMAGE_QUANTIZATIONTABLETYPE eQuantizationTable;
OMX_U8 nQuantizationMatrix[64]; OMX_U8 nQuantizationMatrix[64];
} OMX_IMAGE_PARAM_QUANTIZATIONTABLETYPE; } OMX_IMAGE_PARAM_QUANTIZATIONTABLETYPE;
/** /**
* Huffman table type, the same Huffman table is applied for chroma and * Huffman table type, the same Huffman table is applied for chroma and
* luma component * luma component
*/ */
typedef enum OMX_IMAGE_HUFFMANTABLETYPE { typedef enum OMX_IMAGE_HUFFMANTABLETYPE {
OMX_IMAGE_HuffmanTableAC = 0, OMX_IMAGE_HuffmanTableAC = 0,
OMX_IMAGE_HuffmanTableDC, OMX_IMAGE_HuffmanTableDC,
OMX_IMAGE_HuffmanTableACLuma, OMX_IMAGE_HuffmanTableACLuma,
OMX_IMAGE_HuffmanTableACChroma, OMX_IMAGE_HuffmanTableACChroma,
OMX_IMAGE_HuffmanTableDCLuma, OMX_IMAGE_HuffmanTableDCLuma,
OMX_IMAGE_HuffmanTableDCChroma, OMX_IMAGE_HuffmanTableDCChroma,
OMX_IMAGE_HuffmanTableKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */ OMX_IMAGE_HuffmanTableKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */
OMX_IMAGE_HuffmanTableVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */ OMX_IMAGE_HuffmanTableVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */
OMX_IMAGE_HuffmanTableMax = 0x7FFFFFFF OMX_IMAGE_HuffmanTableMax = 0x7FFFFFFF
} OMX_IMAGE_HUFFMANTABLETYPE; } OMX_IMAGE_HUFFMANTABLETYPE;
/** /**
* JPEG Huffman table * JPEG Huffman table
* *
* STRUCT MEMBERS: * STRUCT MEMBERS:
* nSize : Size of the structure in bytes * nSize : Size of the structure in bytes
* nVersion : OMX specification version information * nVersion : OMX specification version information
* nPortIndex : Port that this structure applies to * nPortIndex : Port that this structure applies to
* eHuffmanTable : Huffman table type * eHuffmanTable : Huffman table type
* nNumberOfHuffmanCodeOfLength[16] : 0-16, number of Huffman codes of each * nNumberOfHuffmanCodeOfLength[16] : 0-16, number of Huffman codes of each
* possible length * possible length
* nHuffmanTable[256] : 0-255, the size used for AC and DC * nHuffmanTable[256] : 0-255, the size used for AC and DC
* HuffmanTable are 16 and 162 * HuffmanTable are 16 and 162
*/ */
typedef struct OMX_IMAGE_PARAM_HUFFMANTTABLETYPE { typedef struct OMX_IMAGE_PARAM_HUFFMANTTABLETYPE {
OMX_U32 nSize; OMX_U32 nSize;
OMX_VERSIONTYPE nVersion; OMX_VERSIONTYPE nVersion;
OMX_U32 nPortIndex; OMX_U32 nPortIndex;
OMX_IMAGE_HUFFMANTABLETYPE eHuffmanTable; OMX_IMAGE_HUFFMANTABLETYPE eHuffmanTable;
OMX_U8 nNumberOfHuffmanCodeOfLength[16]; OMX_U8 nNumberOfHuffmanCodeOfLength[16];
OMX_U8 nHuffmanTable[256]; OMX_U8 nHuffmanTable[256];
}OMX_IMAGE_PARAM_HUFFMANTTABLETYPE; }OMX_IMAGE_PARAM_HUFFMANTTABLETYPE;
/** @} */ /** @} */
#ifdef __cplusplus #ifdef __cplusplus
} }
#endif /* __cplusplus */ #endif /* __cplusplus */
#endif #endif
/* File EOF */ /* File EOF */
/* /*
* Copyright (c) 2008 The Khronos Group Inc. * Copyright (c) 2008 The Khronos Group Inc.
* *
* Permission is hereby granted, free of charge, to any person obtaining * Permission is hereby granted, free of charge, to any person obtaining
* a copy of this software and associated documentation files (the * a copy of this software and associated documentation files (the
* "Software"), to deal in the Software without restriction, including * "Software"), to deal in the Software without restriction, including
* without limitation the rights to use, copy, modify, merge, publish, * without limitation the rights to use, copy, modify, merge, publish,
* distribute, sublicense, and/or sell copies of the Software, and to * distribute, sublicense, and/or sell copies of the Software, and to
* permit persons to whom the Software is furnished to do so, subject * permit persons to whom the Software is furnished to do so, subject
* to the following conditions: * to the following conditions:
* The above copyright notice and this permission notice shall be included * The above copyright notice and this permission notice shall be included
* in all copies or substantial portions of the Software. * in all copies or substantial portions of the Software.
* *
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
* OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, * CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
* *
*/ */
/** @file OMX_Index.h - OpenMax IL version 1.1.2 /** @file OMX_Index.h - OpenMax IL version 1.1.2
* The OMX_Index header file contains the definitions for both applications * The OMX_Index header file contains the definitions for both applications
* and components . * and components .
*/ */
#ifndef OMX_Index_h #ifndef OMX_Index_h
#define OMX_Index_h #define OMX_Index_h
#ifdef __cplusplus #ifdef __cplusplus
extern "C" { extern "C" {
#endif /* __cplusplus */ #endif /* __cplusplus */
/* Each OMX header must include all required header files to allow the /* Each OMX header must include all required header files to allow the
* header to compile without errors. The includes below are required * header to compile without errors. The includes below are required
* for this header file to compile successfully * for this header file to compile successfully
*/ */
#include <OMX_Types.h> #include <OMX_Types.h>
/** The OMX_INDEXTYPE enumeration is used to select a structure when either /** The OMX_INDEXTYPE enumeration is used to select a structure when either
* getting or setting parameters and/or configuration data. Each entry in * getting or setting parameters and/or configuration data. Each entry in
* this enumeration maps to an OMX specified structure. When the * this enumeration maps to an OMX specified structure. When the
* OMX_GetParameter, OMX_SetParameter, OMX_GetConfig or OMX_SetConfig methods * OMX_GetParameter, OMX_SetParameter, OMX_GetConfig or OMX_SetConfig methods
* are used, the second parameter will always be an entry from this enumeration * are used, the second parameter will always be an entry from this enumeration
* and the third entry will be the structure shown in the comments for the entry. * and the third entry will be the structure shown in the comments for the entry.
* For example, if the application is initializing a cropping function, the * For example, if the application is initializing a cropping function, the
* OMX_SetConfig command would have OMX_IndexConfigCommonInputCrop as the second parameter * OMX_SetConfig command would have OMX_IndexConfigCommonInputCrop as the second parameter
* and would send a pointer to an initialized OMX_RECTTYPE structure as the * and would send a pointer to an initialized OMX_RECTTYPE structure as the
* third parameter. * third parameter.
* *
* The enumeration entries named with the OMX_Config prefix are sent using * The enumeration entries named with the OMX_Config prefix are sent using
* the OMX_SetConfig command and the enumeration entries named with the * the OMX_SetConfig command and the enumeration entries named with the
* OMX_PARAM_ prefix are sent using the OMX_SetParameter command. * OMX_PARAM_ prefix are sent using the OMX_SetParameter command.
*/ */
typedef enum OMX_INDEXTYPE { typedef enum OMX_INDEXTYPE {
OMX_IndexComponentStartUnused = 0x01000000, OMX_IndexComponentStartUnused = 0x01000000,
OMX_IndexParamPriorityMgmt, /**< reference: OMX_PRIORITYMGMTTYPE */ OMX_IndexParamPriorityMgmt, /**< reference: OMX_PRIORITYMGMTTYPE */
OMX_IndexParamAudioInit, /**< reference: OMX_PORT_PARAM_TYPE */ OMX_IndexParamAudioInit, /**< reference: OMX_PORT_PARAM_TYPE */
OMX_IndexParamImageInit, /**< reference: OMX_PORT_PARAM_TYPE */ OMX_IndexParamImageInit, /**< reference: OMX_PORT_PARAM_TYPE */
OMX_IndexParamVideoInit, /**< reference: OMX_PORT_PARAM_TYPE */ OMX_IndexParamVideoInit, /**< reference: OMX_PORT_PARAM_TYPE */
OMX_IndexParamOtherInit, /**< reference: OMX_PORT_PARAM_TYPE */ OMX_IndexParamOtherInit, /**< reference: OMX_PORT_PARAM_TYPE */
OMX_IndexParamNumAvailableStreams, /**< reference: OMX_PARAM_U32TYPE */ OMX_IndexParamNumAvailableStreams, /**< reference: OMX_PARAM_U32TYPE */
OMX_IndexParamActiveStream, /**< reference: OMX_PARAM_U32TYPE */ OMX_IndexParamActiveStream, /**< reference: OMX_PARAM_U32TYPE */
OMX_IndexParamSuspensionPolicy, /**< reference: OMX_PARAM_SUSPENSIONPOLICYTYPE */ OMX_IndexParamSuspensionPolicy, /**< reference: OMX_PARAM_SUSPENSIONPOLICYTYPE */
OMX_IndexParamComponentSuspended, /**< reference: OMX_PARAM_SUSPENSIONTYPE */ OMX_IndexParamComponentSuspended, /**< reference: OMX_PARAM_SUSPENSIONTYPE */
OMX_IndexConfigCapturing, /**< reference: OMX_CONFIG_BOOLEANTYPE */ OMX_IndexConfigCapturing, /**< reference: OMX_CONFIG_BOOLEANTYPE */
OMX_IndexConfigCaptureMode, /**< reference: OMX_CONFIG_CAPTUREMODETYPE */ OMX_IndexConfigCaptureMode, /**< reference: OMX_CONFIG_CAPTUREMODETYPE */
OMX_IndexAutoPauseAfterCapture, /**< reference: OMX_CONFIG_BOOLEANTYPE */ OMX_IndexAutoPauseAfterCapture, /**< reference: OMX_CONFIG_BOOLEANTYPE */
OMX_IndexParamContentURI, /**< reference: OMX_PARAM_CONTENTURITYPE */ OMX_IndexParamContentURI, /**< reference: OMX_PARAM_CONTENTURITYPE */
OMX_IndexParamCustomContentPipe, /**< reference: OMX_PARAM_CONTENTPIPETYPE */ OMX_IndexParamCustomContentPipe, /**< reference: OMX_PARAM_CONTENTPIPETYPE */
OMX_IndexParamDisableResourceConcealment, /**< reference: OMX_RESOURCECONCEALMENTTYPE */ OMX_IndexParamDisableResourceConcealment, /**< reference: OMX_RESOURCECONCEALMENTTYPE */
OMX_IndexConfigMetadataItemCount, /**< reference: OMX_CONFIG_METADATAITEMCOUNTTYPE */ OMX_IndexConfigMetadataItemCount, /**< reference: OMX_CONFIG_METADATAITEMCOUNTTYPE */
OMX_IndexConfigContainerNodeCount, /**< reference: OMX_CONFIG_CONTAINERNODECOUNTTYPE */ OMX_IndexConfigContainerNodeCount, /**< reference: OMX_CONFIG_CONTAINERNODECOUNTTYPE */
OMX_IndexConfigMetadataItem, /**< reference: OMX_CONFIG_METADATAITEMTYPE */ OMX_IndexConfigMetadataItem, /**< reference: OMX_CONFIG_METADATAITEMTYPE */
OMX_IndexConfigCounterNodeID, /**< reference: OMX_CONFIG_CONTAINERNODEIDTYPE */ OMX_IndexConfigCounterNodeID, /**< reference: OMX_CONFIG_CONTAINERNODEIDTYPE */
OMX_IndexParamMetadataFilterType, /**< reference: OMX_PARAM_METADATAFILTERTYPE */ OMX_IndexParamMetadataFilterType, /**< reference: OMX_PARAM_METADATAFILTERTYPE */
OMX_IndexParamMetadataKeyFilter, /**< reference: OMX_PARAM_METADATAFILTERTYPE */ OMX_IndexParamMetadataKeyFilter, /**< reference: OMX_PARAM_METADATAFILTERTYPE */
OMX_IndexConfigPriorityMgmt, /**< reference: OMX_PRIORITYMGMTTYPE */ OMX_IndexConfigPriorityMgmt, /**< reference: OMX_PRIORITYMGMTTYPE */
OMX_IndexParamStandardComponentRole, /**< reference: OMX_PARAM_COMPONENTROLETYPE */ OMX_IndexParamStandardComponentRole, /**< reference: OMX_PARAM_COMPONENTROLETYPE */
OMX_IndexPortStartUnused = 0x02000000, OMX_IndexPortStartUnused = 0x02000000,
OMX_IndexParamPortDefinition, /**< reference: OMX_PARAM_PORTDEFINITIONTYPE */ OMX_IndexParamPortDefinition, /**< reference: OMX_PARAM_PORTDEFINITIONTYPE */
OMX_IndexParamCompBufferSupplier, /**< reference: OMX_PARAM_BUFFERSUPPLIERTYPE */ OMX_IndexParamCompBufferSupplier, /**< reference: OMX_PARAM_BUFFERSUPPLIERTYPE */
OMX_IndexReservedStartUnused = 0x03000000, OMX_IndexReservedStartUnused = 0x03000000,
/* Audio parameters and configurations */ /* Audio parameters and configurations */
OMX_IndexAudioStartUnused = 0x04000000, OMX_IndexAudioStartUnused = 0x04000000,
OMX_IndexParamAudioPortFormat, /**< reference: OMX_AUDIO_PARAM_PORTFORMATTYPE */ OMX_IndexParamAudioPortFormat, /**< reference: OMX_AUDIO_PARAM_PORTFORMATTYPE */
OMX_IndexParamAudioPcm, /**< reference: OMX_AUDIO_PARAM_PCMMODETYPE */ OMX_IndexParamAudioPcm, /**< reference: OMX_AUDIO_PARAM_PCMMODETYPE */
OMX_IndexParamAudioAac, /**< reference: OMX_AUDIO_PARAM_AACPROFILETYPE */ OMX_IndexParamAudioAac, /**< reference: OMX_AUDIO_PARAM_AACPROFILETYPE */
OMX_IndexParamAudioRa, /**< reference: OMX_AUDIO_PARAM_RATYPE */ OMX_IndexParamAudioRa, /**< reference: OMX_AUDIO_PARAM_RATYPE */
OMX_IndexParamAudioMp3, /**< reference: OMX_AUDIO_PARAM_MP3TYPE */ OMX_IndexParamAudioMp3, /**< reference: OMX_AUDIO_PARAM_MP3TYPE */
OMX_IndexParamAudioAdpcm, /**< reference: OMX_AUDIO_PARAM_ADPCMTYPE */ OMX_IndexParamAudioAdpcm, /**< reference: OMX_AUDIO_PARAM_ADPCMTYPE */
OMX_IndexParamAudioG723, /**< reference: OMX_AUDIO_PARAM_G723TYPE */ OMX_IndexParamAudioG723, /**< reference: OMX_AUDIO_PARAM_G723TYPE */
OMX_IndexParamAudioG729, /**< reference: OMX_AUDIO_PARAM_G729TYPE */ OMX_IndexParamAudioG729, /**< reference: OMX_AUDIO_PARAM_G729TYPE */
OMX_IndexParamAudioAmr, /**< reference: OMX_AUDIO_PARAM_AMRTYPE */ OMX_IndexParamAudioAmr, /**< reference: OMX_AUDIO_PARAM_AMRTYPE */
OMX_IndexParamAudioWma, /**< reference: OMX_AUDIO_PARAM_WMATYPE */ OMX_IndexParamAudioWma, /**< reference: OMX_AUDIO_PARAM_WMATYPE */
OMX_IndexParamAudioSbc, /**< reference: OMX_AUDIO_PARAM_SBCTYPE */ OMX_IndexParamAudioSbc, /**< reference: OMX_AUDIO_PARAM_SBCTYPE */
OMX_IndexParamAudioMidi, /**< reference: OMX_AUDIO_PARAM_MIDITYPE */ OMX_IndexParamAudioMidi, /**< reference: OMX_AUDIO_PARAM_MIDITYPE */
OMX_IndexParamAudioGsm_FR, /**< reference: OMX_AUDIO_PARAM_GSMFRTYPE */ OMX_IndexParamAudioGsm_FR, /**< reference: OMX_AUDIO_PARAM_GSMFRTYPE */
OMX_IndexParamAudioMidiLoadUserSound, /**< reference: OMX_AUDIO_PARAM_MIDILOADUSERSOUNDTYPE */ OMX_IndexParamAudioMidiLoadUserSound, /**< reference: OMX_AUDIO_PARAM_MIDILOADUSERSOUNDTYPE */
OMX_IndexParamAudioG726, /**< reference: OMX_AUDIO_PARAM_G726TYPE */ OMX_IndexParamAudioG726, /**< reference: OMX_AUDIO_PARAM_G726TYPE */
OMX_IndexParamAudioGsm_EFR, /**< reference: OMX_AUDIO_PARAM_GSMEFRTYPE */ OMX_IndexParamAudioGsm_EFR, /**< reference: OMX_AUDIO_PARAM_GSMEFRTYPE */
OMX_IndexParamAudioGsm_HR, /**< reference: OMX_AUDIO_PARAM_GSMHRTYPE */ OMX_IndexParamAudioGsm_HR, /**< reference: OMX_AUDIO_PARAM_GSMHRTYPE */
OMX_IndexParamAudioPdc_FR, /**< reference: OMX_AUDIO_PARAM_PDCFRTYPE */ OMX_IndexParamAudioPdc_FR, /**< reference: OMX_AUDIO_PARAM_PDCFRTYPE */
OMX_IndexParamAudioPdc_EFR, /**< reference: OMX_AUDIO_PARAM_PDCEFRTYPE */ OMX_IndexParamAudioPdc_EFR, /**< reference: OMX_AUDIO_PARAM_PDCEFRTYPE */
OMX_IndexParamAudioPdc_HR, /**< reference: OMX_AUDIO_PARAM_PDCHRTYPE */ OMX_IndexParamAudioPdc_HR, /**< reference: OMX_AUDIO_PARAM_PDCHRTYPE */
OMX_IndexParamAudioTdma_FR, /**< reference: OMX_AUDIO_PARAM_TDMAFRTYPE */ OMX_IndexParamAudioTdma_FR, /**< reference: OMX_AUDIO_PARAM_TDMAFRTYPE */
OMX_IndexParamAudioTdma_EFR, /**< reference: OMX_AUDIO_PARAM_TDMAEFRTYPE */ OMX_IndexParamAudioTdma_EFR, /**< reference: OMX_AUDIO_PARAM_TDMAEFRTYPE */
OMX_IndexParamAudioQcelp8, /**< reference: OMX_AUDIO_PARAM_QCELP8TYPE */ OMX_IndexParamAudioQcelp8, /**< reference: OMX_AUDIO_PARAM_QCELP8TYPE */
OMX_IndexParamAudioQcelp13, /**< reference: OMX_AUDIO_PARAM_QCELP13TYPE */ OMX_IndexParamAudioQcelp13, /**< reference: OMX_AUDIO_PARAM_QCELP13TYPE */
OMX_IndexParamAudioEvrc, /**< reference: OMX_AUDIO_PARAM_EVRCTYPE */ OMX_IndexParamAudioEvrc, /**< reference: OMX_AUDIO_PARAM_EVRCTYPE */
OMX_IndexParamAudioSmv, /**< reference: OMX_AUDIO_PARAM_SMVTYPE */ OMX_IndexParamAudioSmv, /**< reference: OMX_AUDIO_PARAM_SMVTYPE */
OMX_IndexParamAudioVorbis, /**< reference: OMX_AUDIO_PARAM_VORBISTYPE */ OMX_IndexParamAudioVorbis, /**< reference: OMX_AUDIO_PARAM_VORBISTYPE */
OMX_IndexConfigAudioMidiImmediateEvent, /**< reference: OMX_AUDIO_CONFIG_MIDIIMMEDIATEEVENTTYPE */ OMX_IndexConfigAudioMidiImmediateEvent, /**< reference: OMX_AUDIO_CONFIG_MIDIIMMEDIATEEVENTTYPE */
OMX_IndexConfigAudioMidiControl, /**< reference: OMX_AUDIO_CONFIG_MIDICONTROLTYPE */ OMX_IndexConfigAudioMidiControl, /**< reference: OMX_AUDIO_CONFIG_MIDICONTROLTYPE */
OMX_IndexConfigAudioMidiSoundBankProgram, /**< reference: OMX_AUDIO_CONFIG_MIDISOUNDBANKPROGRAMTYPE */ OMX_IndexConfigAudioMidiSoundBankProgram, /**< reference: OMX_AUDIO_CONFIG_MIDISOUNDBANKPROGRAMTYPE */
OMX_IndexConfigAudioMidiStatus, /**< reference: OMX_AUDIO_CONFIG_MIDISTATUSTYPE */ OMX_IndexConfigAudioMidiStatus, /**< reference: OMX_AUDIO_CONFIG_MIDISTATUSTYPE */
OMX_IndexConfigAudioMidiMetaEvent, /**< reference: OMX_AUDIO_CONFIG_MIDIMETAEVENTTYPE */ OMX_IndexConfigAudioMidiMetaEvent, /**< reference: OMX_AUDIO_CONFIG_MIDIMETAEVENTTYPE */
OMX_IndexConfigAudioMidiMetaEventData, /**< reference: OMX_AUDIO_CONFIG_MIDIMETAEVENTDATATYPE */ OMX_IndexConfigAudioMidiMetaEventData, /**< reference: OMX_AUDIO_CONFIG_MIDIMETAEVENTDATATYPE */
OMX_IndexConfigAudioVolume, /**< reference: OMX_AUDIO_CONFIG_VOLUMETYPE */ OMX_IndexConfigAudioVolume, /**< reference: OMX_AUDIO_CONFIG_VOLUMETYPE */
OMX_IndexConfigAudioBalance, /**< reference: OMX_AUDIO_CONFIG_BALANCETYPE */ OMX_IndexConfigAudioBalance, /**< reference: OMX_AUDIO_CONFIG_BALANCETYPE */
OMX_IndexConfigAudioChannelMute, /**< reference: OMX_AUDIO_CONFIG_CHANNELMUTETYPE */ OMX_IndexConfigAudioChannelMute, /**< reference: OMX_AUDIO_CONFIG_CHANNELMUTETYPE */
OMX_IndexConfigAudioMute, /**< reference: OMX_AUDIO_CONFIG_MUTETYPE */ OMX_IndexConfigAudioMute, /**< reference: OMX_AUDIO_CONFIG_MUTETYPE */
OMX_IndexConfigAudioLoudness, /**< reference: OMX_AUDIO_CONFIG_LOUDNESSTYPE */ OMX_IndexConfigAudioLoudness, /**< reference: OMX_AUDIO_CONFIG_LOUDNESSTYPE */
OMX_IndexConfigAudioEchoCancelation, /**< reference: OMX_AUDIO_CONFIG_ECHOCANCELATIONTYPE */ OMX_IndexConfigAudioEchoCancelation, /**< reference: OMX_AUDIO_CONFIG_ECHOCANCELATIONTYPE */
OMX_IndexConfigAudioNoiseReduction, /**< reference: OMX_AUDIO_CONFIG_NOISEREDUCTIONTYPE */ OMX_IndexConfigAudioNoiseReduction, /**< reference: OMX_AUDIO_CONFIG_NOISEREDUCTIONTYPE */
OMX_IndexConfigAudioBass, /**< reference: OMX_AUDIO_CONFIG_BASSTYPE */ OMX_IndexConfigAudioBass, /**< reference: OMX_AUDIO_CONFIG_BASSTYPE */
OMX_IndexConfigAudioTreble, /**< reference: OMX_AUDIO_CONFIG_TREBLETYPE */ OMX_IndexConfigAudioTreble, /**< reference: OMX_AUDIO_CONFIG_TREBLETYPE */
OMX_IndexConfigAudioStereoWidening, /**< reference: OMX_AUDIO_CONFIG_STEREOWIDENINGTYPE */ OMX_IndexConfigAudioStereoWidening, /**< reference: OMX_AUDIO_CONFIG_STEREOWIDENINGTYPE */
OMX_IndexConfigAudioChorus, /**< reference: OMX_AUDIO_CONFIG_CHORUSTYPE */ OMX_IndexConfigAudioChorus, /**< reference: OMX_AUDIO_CONFIG_CHORUSTYPE */
OMX_IndexConfigAudioEqualizer, /**< reference: OMX_AUDIO_CONFIG_EQUALIZERTYPE */ OMX_IndexConfigAudioEqualizer, /**< reference: OMX_AUDIO_CONFIG_EQUALIZERTYPE */
OMX_IndexConfigAudioReverberation, /**< reference: OMX_AUDIO_CONFIG_REVERBERATIONTYPE */ OMX_IndexConfigAudioReverberation, /**< reference: OMX_AUDIO_CONFIG_REVERBERATIONTYPE */
OMX_IndexConfigAudioChannelVolume, /**< reference: OMX_AUDIO_CONFIG_CHANNELVOLUMETYPE */ OMX_IndexConfigAudioChannelVolume, /**< reference: OMX_AUDIO_CONFIG_CHANNELVOLUMETYPE */
/* Image specific parameters and configurations */ /* Image specific parameters and configurations */
OMX_IndexImageStartUnused = 0x05000000, OMX_IndexImageStartUnused = 0x05000000,
OMX_IndexParamImagePortFormat, /**< reference: OMX_IMAGE_PARAM_PORTFORMATTYPE */ OMX_IndexParamImagePortFormat, /**< reference: OMX_IMAGE_PARAM_PORTFORMATTYPE */
OMX_IndexParamFlashControl, /**< reference: OMX_IMAGE_PARAM_FLASHCONTROLTYPE */ OMX_IndexParamFlashControl, /**< reference: OMX_IMAGE_PARAM_FLASHCONTROLTYPE */
OMX_IndexConfigFocusControl, /**< reference: OMX_IMAGE_CONFIG_FOCUSCONTROLTYPE */ OMX_IndexConfigFocusControl, /**< reference: OMX_IMAGE_CONFIG_FOCUSCONTROLTYPE */
OMX_IndexParamQFactor, /**< reference: OMX_IMAGE_PARAM_QFACTORTYPE */ OMX_IndexParamQFactor, /**< reference: OMX_IMAGE_PARAM_QFACTORTYPE */
OMX_IndexParamQuantizationTable, /**< reference: OMX_IMAGE_PARAM_QUANTIZATIONTABLETYPE */ OMX_IndexParamQuantizationTable, /**< reference: OMX_IMAGE_PARAM_QUANTIZATIONTABLETYPE */
OMX_IndexParamHuffmanTable, /**< reference: OMX_IMAGE_PARAM_HUFFMANTTABLETYPE */ OMX_IndexParamHuffmanTable, /**< reference: OMX_IMAGE_PARAM_HUFFMANTTABLETYPE */
OMX_IndexConfigFlashControl, /**< reference: OMX_IMAGE_PARAM_FLASHCONTROLTYPE */ OMX_IndexConfigFlashControl, /**< reference: OMX_IMAGE_PARAM_FLASHCONTROLTYPE */
/* Video specific parameters and configurations */ /* Video specific parameters and configurations */
OMX_IndexVideoStartUnused = 0x06000000, OMX_IndexVideoStartUnused = 0x06000000,
OMX_IndexParamVideoPortFormat, /**< reference: OMX_VIDEO_PARAM_PORTFORMATTYPE */ OMX_IndexParamVideoPortFormat, /**< reference: OMX_VIDEO_PARAM_PORTFORMATTYPE */
OMX_IndexParamVideoQuantization, /**< reference: OMX_VIDEO_PARAM_QUANTIZATIONTYPE */ OMX_IndexParamVideoQuantization, /**< reference: OMX_VIDEO_PARAM_QUANTIZATIONTYPE */
OMX_IndexParamVideoFastUpdate, /**< reference: OMX_VIDEO_PARAM_VIDEOFASTUPDATETYPE */ OMX_IndexParamVideoFastUpdate, /**< reference: OMX_VIDEO_PARAM_VIDEOFASTUPDATETYPE */
OMX_IndexParamVideoBitrate, /**< reference: OMX_VIDEO_PARAM_BITRATETYPE */ OMX_IndexParamVideoBitrate, /**< reference: OMX_VIDEO_PARAM_BITRATETYPE */
OMX_IndexParamVideoMotionVector, /**< reference: OMX_VIDEO_PARAM_MOTIONVECTORTYPE */ OMX_IndexParamVideoMotionVector, /**< reference: OMX_VIDEO_PARAM_MOTIONVECTORTYPE */
OMX_IndexParamVideoIntraRefresh, /**< reference: OMX_VIDEO_PARAM_INTRAREFRESHTYPE */ OMX_IndexParamVideoIntraRefresh, /**< reference: OMX_VIDEO_PARAM_INTRAREFRESHTYPE */
OMX_IndexParamVideoErrorCorrection, /**< reference: OMX_VIDEO_PARAM_ERRORCORRECTIONTYPE */ OMX_IndexParamVideoErrorCorrection, /**< reference: OMX_VIDEO_PARAM_ERRORCORRECTIONTYPE */
OMX_IndexParamVideoVBSMC, /**< reference: OMX_VIDEO_PARAM_VBSMCTYPE */ OMX_IndexParamVideoVBSMC, /**< reference: OMX_VIDEO_PARAM_VBSMCTYPE */
OMX_IndexParamVideoMpeg2, /**< reference: OMX_VIDEO_PARAM_MPEG2TYPE */ OMX_IndexParamVideoMpeg2, /**< reference: OMX_VIDEO_PARAM_MPEG2TYPE */
OMX_IndexParamVideoMpeg4, /**< reference: OMX_VIDEO_PARAM_MPEG4TYPE */ OMX_IndexParamVideoMpeg4, /**< reference: OMX_VIDEO_PARAM_MPEG4TYPE */
OMX_IndexParamVideoWmv, /**< reference: OMX_VIDEO_PARAM_WMVTYPE */ OMX_IndexParamVideoWmv, /**< reference: OMX_VIDEO_PARAM_WMVTYPE */
OMX_IndexParamVideoRv, /**< reference: OMX_VIDEO_PARAM_RVTYPE */ OMX_IndexParamVideoRv, /**< reference: OMX_VIDEO_PARAM_RVTYPE */
OMX_IndexParamVideoAvc, /**< reference: OMX_VIDEO_PARAM_AVCTYPE */ OMX_IndexParamVideoAvc, /**< reference: OMX_VIDEO_PARAM_AVCTYPE */
OMX_IndexParamVideoH263, /**< reference: OMX_VIDEO_PARAM_H263TYPE */ OMX_IndexParamVideoH263, /**< reference: OMX_VIDEO_PARAM_H263TYPE */
OMX_IndexParamVideoProfileLevelQuerySupported, /**< reference: OMX_VIDEO_PARAM_PROFILELEVELTYPE */ OMX_IndexParamVideoProfileLevelQuerySupported, /**< reference: OMX_VIDEO_PARAM_PROFILELEVELTYPE */
OMX_IndexParamVideoProfileLevelCurrent, /**< reference: OMX_VIDEO_PARAM_PROFILELEVELTYPE */ OMX_IndexParamVideoProfileLevelCurrent, /**< reference: OMX_VIDEO_PARAM_PROFILELEVELTYPE */
OMX_IndexConfigVideoBitrate, /**< reference: OMX_VIDEO_CONFIG_BITRATETYPE */ OMX_IndexConfigVideoBitrate, /**< reference: OMX_VIDEO_CONFIG_BITRATETYPE */
OMX_IndexConfigVideoFramerate, /**< reference: OMX_CONFIG_FRAMERATETYPE */ OMX_IndexConfigVideoFramerate, /**< reference: OMX_CONFIG_FRAMERATETYPE */
OMX_IndexConfigVideoIntraVOPRefresh, /**< reference: OMX_CONFIG_INTRAREFRESHVOPTYPE */ OMX_IndexConfigVideoIntraVOPRefresh, /**< reference: OMX_CONFIG_INTRAREFRESHVOPTYPE */
OMX_IndexConfigVideoIntraMBRefresh, /**< reference: OMX_CONFIG_MACROBLOCKERRORMAPTYPE */ OMX_IndexConfigVideoIntraMBRefresh, /**< reference: OMX_CONFIG_MACROBLOCKERRORMAPTYPE */
OMX_IndexConfigVideoMBErrorReporting, /**< reference: OMX_CONFIG_MBERRORREPORTINGTYPE */ OMX_IndexConfigVideoMBErrorReporting, /**< reference: OMX_CONFIG_MBERRORREPORTINGTYPE */
OMX_IndexParamVideoMacroblocksPerFrame, /**< reference: OMX_PARAM_MACROBLOCKSTYPE */ OMX_IndexParamVideoMacroblocksPerFrame, /**< reference: OMX_PARAM_MACROBLOCKSTYPE */
OMX_IndexConfigVideoMacroBlockErrorMap, /**< reference: OMX_CONFIG_MACROBLOCKERRORMAPTYPE */ OMX_IndexConfigVideoMacroBlockErrorMap, /**< reference: OMX_CONFIG_MACROBLOCKERRORMAPTYPE */
OMX_IndexParamVideoSliceFMO, /**< reference: OMX_VIDEO_PARAM_AVCSLICEFMO */ OMX_IndexParamVideoSliceFMO, /**< reference: OMX_VIDEO_PARAM_AVCSLICEFMO */
OMX_IndexConfigVideoAVCIntraPeriod, /**< reference: OMX_VIDEO_CONFIG_AVCINTRAPERIOD */ OMX_IndexConfigVideoAVCIntraPeriod, /**< reference: OMX_VIDEO_CONFIG_AVCINTRAPERIOD */
OMX_IndexConfigVideoNalSize, /**< reference: OMX_VIDEO_CONFIG_NALSIZE */ OMX_IndexConfigVideoNalSize, /**< reference: OMX_VIDEO_CONFIG_NALSIZE */
/* Image & Video common Configurations */ /* Image & Video common Configurations */
OMX_IndexCommonStartUnused = 0x07000000, OMX_IndexCommonStartUnused = 0x07000000,
OMX_IndexParamCommonDeblocking, /**< reference: OMX_PARAM_DEBLOCKINGTYPE */ OMX_IndexParamCommonDeblocking, /**< reference: OMX_PARAM_DEBLOCKINGTYPE */
OMX_IndexParamCommonSensorMode, /**< reference: OMX_PARAM_SENSORMODETYPE */ OMX_IndexParamCommonSensorMode, /**< reference: OMX_PARAM_SENSORMODETYPE */
OMX_IndexParamCommonInterleave, /**< reference: OMX_PARAM_INTERLEAVETYPE */ OMX_IndexParamCommonInterleave, /**< reference: OMX_PARAM_INTERLEAVETYPE */
OMX_IndexConfigCommonColorFormatConversion, /**< reference: OMX_CONFIG_COLORCONVERSIONTYPE */ OMX_IndexConfigCommonColorFormatConversion, /**< reference: OMX_CONFIG_COLORCONVERSIONTYPE */
OMX_IndexConfigCommonScale, /**< reference: OMX_CONFIG_SCALEFACTORTYPE */ OMX_IndexConfigCommonScale, /**< reference: OMX_CONFIG_SCALEFACTORTYPE */
OMX_IndexConfigCommonImageFilter, /**< reference: OMX_CONFIG_IMAGEFILTERTYPE */ OMX_IndexConfigCommonImageFilter, /**< reference: OMX_CONFIG_IMAGEFILTERTYPE */
OMX_IndexConfigCommonColorEnhancement, /**< reference: OMX_CONFIG_COLORENHANCEMENTTYPE */ OMX_IndexConfigCommonColorEnhancement, /**< reference: OMX_CONFIG_COLORENHANCEMENTTYPE */
OMX_IndexConfigCommonColorKey, /**< reference: OMX_CONFIG_COLORKEYTYPE */ OMX_IndexConfigCommonColorKey, /**< reference: OMX_CONFIG_COLORKEYTYPE */
OMX_IndexConfigCommonColorBlend, /**< reference: OMX_CONFIG_COLORBLENDTYPE */ OMX_IndexConfigCommonColorBlend, /**< reference: OMX_CONFIG_COLORBLENDTYPE */
OMX_IndexConfigCommonFrameStabilisation,/**< reference: OMX_CONFIG_FRAMESTABTYPE */ OMX_IndexConfigCommonFrameStabilisation,/**< reference: OMX_CONFIG_FRAMESTABTYPE */
OMX_IndexConfigCommonRotate, /**< reference: OMX_CONFIG_ROTATIONTYPE */ OMX_IndexConfigCommonRotate, /**< reference: OMX_CONFIG_ROTATIONTYPE */
OMX_IndexConfigCommonMirror, /**< reference: OMX_CONFIG_MIRRORTYPE */ OMX_IndexConfigCommonMirror, /**< reference: OMX_CONFIG_MIRRORTYPE */
OMX_IndexConfigCommonOutputPosition, /**< reference: OMX_CONFIG_POINTTYPE */ OMX_IndexConfigCommonOutputPosition, /**< reference: OMX_CONFIG_POINTTYPE */
OMX_IndexConfigCommonInputCrop, /**< reference: OMX_CONFIG_RECTTYPE */ OMX_IndexConfigCommonInputCrop, /**< reference: OMX_CONFIG_RECTTYPE */
OMX_IndexConfigCommonOutputCrop, /**< reference: OMX_CONFIG_RECTTYPE */ OMX_IndexConfigCommonOutputCrop, /**< reference: OMX_CONFIG_RECTTYPE */
OMX_IndexConfigCommonDigitalZoom, /**< reference: OMX_CONFIG_SCALEFACTORTYPE */ OMX_IndexConfigCommonDigitalZoom, /**< reference: OMX_CONFIG_SCALEFACTORTYPE */
OMX_IndexConfigCommonOpticalZoom, /**< reference: OMX_CONFIG_SCALEFACTORTYPE*/ OMX_IndexConfigCommonOpticalZoom, /**< reference: OMX_CONFIG_SCALEFACTORTYPE*/
OMX_IndexConfigCommonWhiteBalance, /**< reference: OMX_CONFIG_WHITEBALCONTROLTYPE */ OMX_IndexConfigCommonWhiteBalance, /**< reference: OMX_CONFIG_WHITEBALCONTROLTYPE */
OMX_IndexConfigCommonExposure, /**< reference: OMX_CONFIG_EXPOSURECONTROLTYPE */ OMX_IndexConfigCommonExposure, /**< reference: OMX_CONFIG_EXPOSURECONTROLTYPE */
OMX_IndexConfigCommonContrast, /**< reference: OMX_CONFIG_CONTRASTTYPE */ OMX_IndexConfigCommonContrast, /**< reference: OMX_CONFIG_CONTRASTTYPE */
OMX_IndexConfigCommonBrightness, /**< reference: OMX_CONFIG_BRIGHTNESSTYPE */ OMX_IndexConfigCommonBrightness, /**< reference: OMX_CONFIG_BRIGHTNESSTYPE */
OMX_IndexConfigCommonBacklight, /**< reference: OMX_CONFIG_BACKLIGHTTYPE */ OMX_IndexConfigCommonBacklight, /**< reference: OMX_CONFIG_BACKLIGHTTYPE */
OMX_IndexConfigCommonGamma, /**< reference: OMX_CONFIG_GAMMATYPE */ OMX_IndexConfigCommonGamma, /**< reference: OMX_CONFIG_GAMMATYPE */
OMX_IndexConfigCommonSaturation, /**< reference: OMX_CONFIG_SATURATIONTYPE */ OMX_IndexConfigCommonSaturation, /**< reference: OMX_CONFIG_SATURATIONTYPE */
OMX_IndexConfigCommonLightness, /**< reference: OMX_CONFIG_LIGHTNESSTYPE */ OMX_IndexConfigCommonLightness, /**< reference: OMX_CONFIG_LIGHTNESSTYPE */
OMX_IndexConfigCommonExclusionRect, /**< reference: OMX_CONFIG_RECTTYPE */ OMX_IndexConfigCommonExclusionRect, /**< reference: OMX_CONFIG_RECTTYPE */
OMX_IndexConfigCommonDithering, /**< reference: OMX_CONFIG_DITHERTYPE */ OMX_IndexConfigCommonDithering, /**< reference: OMX_CONFIG_DITHERTYPE */
OMX_IndexConfigCommonPlaneBlend, /**< reference: OMX_CONFIG_PLANEBLENDTYPE */ OMX_IndexConfigCommonPlaneBlend, /**< reference: OMX_CONFIG_PLANEBLENDTYPE */
OMX_IndexConfigCommonExposureValue, /**< reference: OMX_CONFIG_EXPOSUREVALUETYPE */ OMX_IndexConfigCommonExposureValue, /**< reference: OMX_CONFIG_EXPOSUREVALUETYPE */
OMX_IndexConfigCommonOutputSize, /**< reference: OMX_FRAMESIZETYPE */ OMX_IndexConfigCommonOutputSize, /**< reference: OMX_FRAMESIZETYPE */
OMX_IndexParamCommonExtraQuantData, /**< reference: OMX_OTHER_EXTRADATATYPE */ OMX_IndexParamCommonExtraQuantData, /**< reference: OMX_OTHER_EXTRADATATYPE */
OMX_IndexConfigCommonFocusRegion, /**< reference: OMX_CONFIG_FOCUSREGIONTYPE */ OMX_IndexConfigCommonFocusRegion, /**< reference: OMX_CONFIG_FOCUSREGIONTYPE */
OMX_IndexConfigCommonFocusStatus, /**< reference: OMX_PARAM_FOCUSSTATUSTYPE */ OMX_IndexConfigCommonFocusStatus, /**< reference: OMX_PARAM_FOCUSSTATUSTYPE */
OMX_IndexConfigCommonTransitionEffect, /**< reference: OMX_CONFIG_TRANSITIONEFFECTTYPE */ OMX_IndexConfigCommonTransitionEffect, /**< reference: OMX_CONFIG_TRANSITIONEFFECTTYPE */
/* Reserved Configuration range */ /* Reserved Configuration range */
OMX_IndexOtherStartUnused = 0x08000000, OMX_IndexOtherStartUnused = 0x08000000,
OMX_IndexParamOtherPortFormat, /**< reference: OMX_OTHER_PARAM_PORTFORMATTYPE */ OMX_IndexParamOtherPortFormat, /**< reference: OMX_OTHER_PARAM_PORTFORMATTYPE */
OMX_IndexConfigOtherPower, /**< reference: OMX_OTHER_CONFIG_POWERTYPE */ OMX_IndexConfigOtherPower, /**< reference: OMX_OTHER_CONFIG_POWERTYPE */
OMX_IndexConfigOtherStats, /**< reference: OMX_OTHER_CONFIG_STATSTYPE */ OMX_IndexConfigOtherStats, /**< reference: OMX_OTHER_CONFIG_STATSTYPE */
/* Reserved Time range */ /* Reserved Time range */
OMX_IndexTimeStartUnused = 0x09000000, OMX_IndexTimeStartUnused = 0x09000000,
OMX_IndexConfigTimeScale, /**< reference: OMX_TIME_CONFIG_SCALETYPE */ OMX_IndexConfigTimeScale, /**< reference: OMX_TIME_CONFIG_SCALETYPE */
OMX_IndexConfigTimeClockState, /**< reference: OMX_TIME_CONFIG_CLOCKSTATETYPE */ OMX_IndexConfigTimeClockState, /**< reference: OMX_TIME_CONFIG_CLOCKSTATETYPE */
OMX_IndexConfigTimeActiveRefClock, /**< reference: OMX_TIME_CONFIG_ACTIVEREFCLOCKTYPE */ OMX_IndexConfigTimeActiveRefClock, /**< reference: OMX_TIME_CONFIG_ACTIVEREFCLOCKTYPE */
OMX_IndexConfigTimeCurrentMediaTime, /**< reference: OMX_TIME_CONFIG_TIMESTAMPTYPE (read only) */ OMX_IndexConfigTimeCurrentMediaTime, /**< reference: OMX_TIME_CONFIG_TIMESTAMPTYPE (read only) */
OMX_IndexConfigTimeCurrentWallTime, /**< reference: OMX_TIME_CONFIG_TIMESTAMPTYPE (read only) */ OMX_IndexConfigTimeCurrentWallTime, /**< reference: OMX_TIME_CONFIG_TIMESTAMPTYPE (read only) */
OMX_IndexConfigTimeCurrentAudioReference, /**< reference: OMX_TIME_CONFIG_TIMESTAMPTYPE (write only) */ OMX_IndexConfigTimeCurrentAudioReference, /**< reference: OMX_TIME_CONFIG_TIMESTAMPTYPE (write only) */
OMX_IndexConfigTimeCurrentVideoReference, /**< reference: OMX_TIME_CONFIG_TIMESTAMPTYPE (write only) */ OMX_IndexConfigTimeCurrentVideoReference, /**< reference: OMX_TIME_CONFIG_TIMESTAMPTYPE (write only) */
OMX_IndexConfigTimeMediaTimeRequest, /**< reference: OMX_TIME_CONFIG_MEDIATIMEREQUESTTYPE (write only) */ OMX_IndexConfigTimeMediaTimeRequest, /**< reference: OMX_TIME_CONFIG_MEDIATIMEREQUESTTYPE (write only) */
OMX_IndexConfigTimeClientStartTime, /**<reference: OMX_TIME_CONFIG_TIMESTAMPTYPE (write only) */ OMX_IndexConfigTimeClientStartTime, /**<reference: OMX_TIME_CONFIG_TIMESTAMPTYPE (write only) */
OMX_IndexConfigTimePosition, /**< reference: OMX_TIME_CONFIG_TIMESTAMPTYPE */ OMX_IndexConfigTimePosition, /**< reference: OMX_TIME_CONFIG_TIMESTAMPTYPE */
OMX_IndexConfigTimeSeekMode, /**< reference: OMX_TIME_CONFIG_SEEKMODETYPE */ OMX_IndexConfigTimeSeekMode, /**< reference: OMX_TIME_CONFIG_SEEKMODETYPE */
OMX_IndexKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */ OMX_IndexKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */
/* Vendor specific area */ /* Vendor specific area */
OMX_IndexVendorStartUnused = 0x7F000000, OMX_IndexVendorStartUnused = 0x7F000000,
/* Vendor specific structures should be in the range of 0x7F000000 /* Vendor specific structures should be in the range of 0x7F000000
to 0x7FFFFFFE. This range is not broken out by vendor, so to 0x7FFFFFFE. This range is not broken out by vendor, so
private indexes are not guaranteed unique and therefore should private indexes are not guaranteed unique and therefore should
only be sent to the appropriate component. */ only be sent to the appropriate component. */
OMX_IndexMax = 0x7FFFFFFF OMX_IndexMax = 0x7FFFFFFF
} OMX_INDEXTYPE; } OMX_INDEXTYPE;
#ifdef __cplusplus #ifdef __cplusplus
} }
#endif /* __cplusplus */ #endif /* __cplusplus */
#endif #endif
/* File EOF */ /* File EOF */
/* /*
* Copyright (c) 2008 The Khronos Group Inc. * Copyright (c) 2008 The Khronos Group Inc.
* *
* Permission is hereby granted, free of charge, to any person obtaining * Permission is hereby granted, free of charge, to any person obtaining
* a copy of this software and associated documentation files (the * a copy of this software and associated documentation files (the
* "Software"), to deal in the Software without restriction, including * "Software"), to deal in the Software without restriction, including
* without limitation the rights to use, copy, modify, merge, publish, * without limitation the rights to use, copy, modify, merge, publish,
* distribute, sublicense, and/or sell copies of the Software, and to * distribute, sublicense, and/or sell copies of the Software, and to
* permit persons to whom the Software is furnished to do so, subject * permit persons to whom the Software is furnished to do so, subject
* to the following conditions: * to the following conditions:
* The above copyright notice and this permission notice shall be included * The above copyright notice and this permission notice shall be included
* in all copies or substantial portions of the Software. * in all copies or substantial portions of the Software.
* *
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
* OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, * CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
* *
*/ */
/** @file OMX_Other.h - OpenMax IL version 1.1.2 /** @file OMX_Other.h - OpenMax IL version 1.1.2
* The structures needed by Other components to exchange * The structures needed by Other components to exchange
* parameters and configuration data with the components. * parameters and configuration data with the components.
*/ */
#ifndef OMX_Other_h #ifndef OMX_Other_h
#define OMX_Other_h #define OMX_Other_h
#ifdef __cplusplus #ifdef __cplusplus
extern "C" { extern "C" {
#endif /* __cplusplus */ #endif /* __cplusplus */
/* Each OMX header must include all required header files to allow the /* Each OMX header must include all required header files to allow the
* header to compile without errors. The includes below are required * header to compile without errors. The includes below are required
* for this header file to compile successfully * for this header file to compile successfully
*/ */
#include <OMX_Core.h> #include <OMX_Core.h>
/** /**
* Enumeration of possible data types which match to multiple domains or no * Enumeration of possible data types which match to multiple domains or no
* domain at all. For types which are vendor specific, a value above * domain at all. For types which are vendor specific, a value above
* OMX_OTHER_VENDORTSTART should be used. * OMX_OTHER_VENDORTSTART should be used.
*/ */
typedef enum OMX_OTHER_FORMATTYPE { typedef enum OMX_OTHER_FORMATTYPE {
OMX_OTHER_FormatTime = 0, /**< Transmission of various timestamps, elapsed time, OMX_OTHER_FormatTime = 0, /**< Transmission of various timestamps, elapsed time,
time deltas, etc */ time deltas, etc */
OMX_OTHER_FormatPower, /**< Perhaps used for enabling/disabling power OMX_OTHER_FormatPower, /**< Perhaps used for enabling/disabling power
management, setting clocks? */ management, setting clocks? */
OMX_OTHER_FormatStats, /**< Could be things such as frame rate, frames OMX_OTHER_FormatStats, /**< Could be things such as frame rate, frames
dropped, etc */ dropped, etc */
OMX_OTHER_FormatBinary, /**< Arbitrary binary data */ OMX_OTHER_FormatBinary, /**< Arbitrary binary data */
OMX_OTHER_FormatVendorReserved = 1000, /**< Starting value for vendor specific OMX_OTHER_FormatVendorReserved = 1000, /**< Starting value for vendor specific
formats */ formats */
OMX_OTHER_FormatKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */ OMX_OTHER_FormatKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */
OMX_OTHER_FormatVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */ OMX_OTHER_FormatVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */
OMX_OTHER_FormatMax = 0x7FFFFFFF OMX_OTHER_FormatMax = 0x7FFFFFFF
} OMX_OTHER_FORMATTYPE; } OMX_OTHER_FORMATTYPE;
/** /**
* Enumeration of seek modes. * Enumeration of seek modes.
*/ */
typedef enum OMX_TIME_SEEKMODETYPE { typedef enum OMX_TIME_SEEKMODETYPE {
OMX_TIME_SeekModeFast = 0, /**< Prefer seeking to an approximation OMX_TIME_SeekModeFast = 0, /**< Prefer seeking to an approximation
* of the requested seek position over * of the requested seek position over
* the actual seek position if it * the actual seek position if it
* results in a faster seek. */ * results in a faster seek. */
OMX_TIME_SeekModeAccurate, /**< Prefer seeking to the actual seek OMX_TIME_SeekModeAccurate, /**< Prefer seeking to the actual seek
* position over an approximation * position over an approximation
* of the requested seek position even * of the requested seek position even
* if it results in a slower seek. */ * if it results in a slower seek. */
OMX_TIME_SeekModeKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */ OMX_TIME_SeekModeKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */
OMX_TIME_SeekModeVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */ OMX_TIME_SeekModeVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */
OMX_TIME_SeekModeMax = 0x7FFFFFFF OMX_TIME_SeekModeMax = 0x7FFFFFFF
} OMX_TIME_SEEKMODETYPE; } OMX_TIME_SEEKMODETYPE;
/* Structure representing the seekmode of the component */ /* Structure representing the seekmode of the component */
typedef struct OMX_TIME_CONFIG_SEEKMODETYPE { typedef struct OMX_TIME_CONFIG_SEEKMODETYPE {
OMX_U32 nSize; /**< size of the structure in bytes */ OMX_U32 nSize; /**< size of the structure in bytes */
OMX_VERSIONTYPE nVersion; /**< OMX specification version information */ OMX_VERSIONTYPE nVersion; /**< OMX specification version information */
OMX_TIME_SEEKMODETYPE eType; /**< The seek mode */ OMX_TIME_SEEKMODETYPE eType; /**< The seek mode */
} OMX_TIME_CONFIG_SEEKMODETYPE; } OMX_TIME_CONFIG_SEEKMODETYPE;
/** Structure representing a time stamp used with the following configs /** Structure representing a time stamp used with the following configs
* on the Clock Component (CC): * on the Clock Component (CC):
* *
* OMX_IndexConfigTimeCurrentWallTime: query of the CC’s current wall * OMX_IndexConfigTimeCurrentWallTime: query of the CC’s current wall
* time * time
* OMX_IndexConfigTimeCurrentMediaTime: query of the CC’s current media * OMX_IndexConfigTimeCurrentMediaTime: query of the CC’s current media
* time * time
* OMX_IndexConfigTimeCurrentAudioReference and * OMX_IndexConfigTimeCurrentAudioReference and
* OMX_IndexConfigTimeCurrentVideoReference: audio/video reference * OMX_IndexConfigTimeCurrentVideoReference: audio/video reference
* clock sending SC its reference time * clock sending SC its reference time
* OMX_IndexConfigTimeClientStartTime: a Clock Component client sends * OMX_IndexConfigTimeClientStartTime: a Clock Component client sends
* this structure to the Clock Component via a SetConfig on its * this structure to the Clock Component via a SetConfig on its
* client port when it receives a buffer with * client port when it receives a buffer with
* OMX_BUFFERFLAG_STARTTIME set. It must use the timestamp * OMX_BUFFERFLAG_STARTTIME set. It must use the timestamp
* specified by that buffer for nStartTimestamp. * specified by that buffer for nStartTimestamp.
* *
* It’s also used with the following config on components in general: * It’s also used with the following config on components in general:
* *
* OMX_IndexConfigTimePosition: IL client querying component position * OMX_IndexConfigTimePosition: IL client querying component position
* (GetConfig) or commanding a component to seek to the given location * (GetConfig) or commanding a component to seek to the given location
* (SetConfig) * (SetConfig)
*/ */
typedef struct OMX_TIME_CONFIG_TIMESTAMPTYPE { typedef struct OMX_TIME_CONFIG_TIMESTAMPTYPE {
OMX_U32 nSize; /**< size of the structure in bytes */ OMX_U32 nSize; /**< size of the structure in bytes */
OMX_VERSIONTYPE nVersion; /**< OMX specification version OMX_VERSIONTYPE nVersion; /**< OMX specification version
* information */ * information */
OMX_U32 nPortIndex; /**< port that this structure applies to */ OMX_U32 nPortIndex; /**< port that this structure applies to */
OMX_TICKS nTimestamp; /**< timestamp .*/ OMX_TICKS nTimestamp; /**< timestamp .*/
} OMX_TIME_CONFIG_TIMESTAMPTYPE; } OMX_TIME_CONFIG_TIMESTAMPTYPE;
/** Enumeration of possible reference clocks to the media time. */ /** Enumeration of possible reference clocks to the media time. */
typedef enum OMX_TIME_UPDATETYPE { typedef enum OMX_TIME_UPDATETYPE {
OMX_TIME_UpdateRequestFulfillment, /**< Update is the fulfillment of a media time request. */ OMX_TIME_UpdateRequestFulfillment, /**< Update is the fulfillment of a media time request. */
OMX_TIME_UpdateScaleChanged, /**< Update was generated because the scale chagned. */ OMX_TIME_UpdateScaleChanged, /**< Update was generated because the scale chagned. */
OMX_TIME_UpdateClockStateChanged, /**< Update was generated because the clock state changed. */ OMX_TIME_UpdateClockStateChanged, /**< Update was generated because the clock state changed. */
OMX_TIME_UpdateKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */ OMX_TIME_UpdateKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */
OMX_TIME_UpdateVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */ OMX_TIME_UpdateVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */
OMX_TIME_UpdateMax = 0x7FFFFFFF OMX_TIME_UpdateMax = 0x7FFFFFFF
} OMX_TIME_UPDATETYPE; } OMX_TIME_UPDATETYPE;
/** Enumeration of possible reference clocks to the media time. */ /** Enumeration of possible reference clocks to the media time. */
typedef enum OMX_TIME_REFCLOCKTYPE { typedef enum OMX_TIME_REFCLOCKTYPE {
OMX_TIME_RefClockNone, /**< Use no references. */ OMX_TIME_RefClockNone, /**< Use no references. */
OMX_TIME_RefClockAudio, /**< Use references sent through OMX_IndexConfigTimeCurrentAudioReference */ OMX_TIME_RefClockAudio, /**< Use references sent through OMX_IndexConfigTimeCurrentAudioReference */
OMX_TIME_RefClockVideo, /**< Use references sent through OMX_IndexConfigTimeCurrentVideoReference */ OMX_TIME_RefClockVideo, /**< Use references sent through OMX_IndexConfigTimeCurrentVideoReference */
OMX_TIME_RefClockKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */ OMX_TIME_RefClockKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */
OMX_TIME_RefClockVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */ OMX_TIME_RefClockVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */
OMX_TIME_RefClockMax = 0x7FFFFFFF OMX_TIME_RefClockMax = 0x7FFFFFFF
} OMX_TIME_REFCLOCKTYPE; } OMX_TIME_REFCLOCKTYPE;
/** Enumeration of clock states. */ /** Enumeration of clock states. */
typedef enum OMX_TIME_CLOCKSTATE { typedef enum OMX_TIME_CLOCKSTATE {
OMX_TIME_ClockStateRunning, /**< Clock running. */ OMX_TIME_ClockStateRunning, /**< Clock running. */
OMX_TIME_ClockStateWaitingForStartTime, /**< Clock waiting until the OMX_TIME_ClockStateWaitingForStartTime, /**< Clock waiting until the
* prescribed clients emit their * prescribed clients emit their
* start time. */ * start time. */
OMX_TIME_ClockStateStopped, /**< Clock stopped. */ OMX_TIME_ClockStateStopped, /**< Clock stopped. */
OMX_TIME_ClockStateKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */ OMX_TIME_ClockStateKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */
OMX_TIME_ClockStateVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */ OMX_TIME_ClockStateVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */
OMX_TIME_ClockStateMax = 0x7FFFFFFF OMX_TIME_ClockStateMax = 0x7FFFFFFF
} OMX_TIME_CLOCKSTATE; } OMX_TIME_CLOCKSTATE;
/** Structure representing a media time request to the clock component. /** Structure representing a media time request to the clock component.
* *
* A client component sends this structure to the Clock Component via a SetConfig * A client component sends this structure to the Clock Component via a SetConfig
* on its client port to specify a media timestamp the Clock Component * on its client port to specify a media timestamp the Clock Component
* should emit. The Clock Component should fulfill the request by sending a * should emit. The Clock Component should fulfill the request by sending a
* OMX_TIME_MEDIATIMETYPE when its media clock matches the requested * OMX_TIME_MEDIATIMETYPE when its media clock matches the requested
* timestamp. * timestamp.
* *
* The client may require a media time request be fulfilled slightly * The client may require a media time request be fulfilled slightly
* earlier than the media time specified. In this case the client specifies * earlier than the media time specified. In this case the client specifies
* an offset which is equal to the difference between wall time corresponding * an offset which is equal to the difference between wall time corresponding
* to the requested media time and the wall time when it will be * to the requested media time and the wall time when it will be
* fulfilled. * fulfilled.
* *
* A client component may uses these requests and the OMX_TIME_MEDIATIMETYPE to * A client component may uses these requests and the OMX_TIME_MEDIATIMETYPE to
* time events according to timestamps. If a client must perform an operation O at * time events according to timestamps. If a client must perform an operation O at
* a time T (e.g. deliver a video frame at its corresponding timestamp), it makes a * a time T (e.g. deliver a video frame at its corresponding timestamp), it makes a
* media time request at T (perhaps specifying an offset to ensure the request fulfillment * media time request at T (perhaps specifying an offset to ensure the request fulfillment
* is a little early). When the clock component passes the resulting OMX_TIME_MEDIATIMETYPE * is a little early). When the clock component passes the resulting OMX_TIME_MEDIATIMETYPE
* structure back to the client component, the client may perform operation O (perhaps having * structure back to the client component, the client may perform operation O (perhaps having
* to wait a slight amount more time itself as specified by the return values). * to wait a slight amount more time itself as specified by the return values).
*/ */
typedef struct OMX_TIME_CONFIG_MEDIATIMEREQUESTTYPE { typedef struct OMX_TIME_CONFIG_MEDIATIMEREQUESTTYPE {
OMX_U32 nSize; /**< size of the structure in bytes */ OMX_U32 nSize; /**< size of the structure in bytes */
OMX_VERSIONTYPE nVersion; /**< OMX specification version information */ OMX_VERSIONTYPE nVersion; /**< OMX specification version information */
OMX_U32 nPortIndex; /**< port that this structure applies to */ OMX_U32 nPortIndex; /**< port that this structure applies to */
OMX_PTR pClientPrivate; /**< Client private data to disabiguate this media time OMX_PTR pClientPrivate; /**< Client private data to disabiguate this media time
* from others (e.g. the number of the frame to deliver). * from others (e.g. the number of the frame to deliver).
* Duplicated in the media time structure that fulfills * Duplicated in the media time structure that fulfills
* this request. A value of zero is reserved for time scale * this request. A value of zero is reserved for time scale
* updates. */ * updates. */
OMX_TICKS nMediaTimestamp; /**< Media timestamp requested.*/ OMX_TICKS nMediaTimestamp; /**< Media timestamp requested.*/
OMX_TICKS nOffset; /**< Amount of wall clock time by which this OMX_TICKS nOffset; /**< Amount of wall clock time by which this
* request should be fulfilled early */ * request should be fulfilled early */
} OMX_TIME_CONFIG_MEDIATIMEREQUESTTYPE; } OMX_TIME_CONFIG_MEDIATIMEREQUESTTYPE;
/**< Structure sent from the clock component client either when fulfilling /**< Structure sent from the clock component client either when fulfilling
* a media time request or when the time scale has changed. * a media time request or when the time scale has changed.
* *
* In the former case the Clock Component fills this structure and times its emission * In the former case the Clock Component fills this structure and times its emission
* to a client component (via the client port) according to the corresponding media * to a client component (via the client port) according to the corresponding media
* time request sent by the client. The Clock Component should time the emission to occur * time request sent by the client. The Clock Component should time the emission to occur
* when the requested timestamp matches the Clock Component's media time but also the * when the requested timestamp matches the Clock Component's media time but also the
* prescribed offset early. * prescribed offset early.
* *
* Upon scale changes the clock component clears the nClientPrivate data, sends the current * Upon scale changes the clock component clears the nClientPrivate data, sends the current
* media time and sets the nScale to the new scale via the client port. It emits a * media time and sets the nScale to the new scale via the client port. It emits a
* OMX_TIME_MEDIATIMETYPE to all clients independent of any requests. This allows clients to * OMX_TIME_MEDIATIMETYPE to all clients independent of any requests. This allows clients to
* alter processing to accomodate scaling. For instance a video component might skip inter-frames * alter processing to accomodate scaling. For instance a video component might skip inter-frames
* in the case of extreme fastforward. Likewise an audio component might add or remove samples * in the case of extreme fastforward. Likewise an audio component might add or remove samples
* from an audio frame to scale audio data. * from an audio frame to scale audio data.
* *
* It is expected that some clock components may not be able to fulfill requests * It is expected that some clock components may not be able to fulfill requests
* at exactly the prescribed time. This is acceptable so long as the request is * at exactly the prescribed time. This is acceptable so long as the request is
* fulfilled at least as early as described and not later. This structure provides * fulfilled at least as early as described and not later. This structure provides
* fields the client may use to wait for the remaining time. * fields the client may use to wait for the remaining time.
* *
* The client may use either the nOffset or nWallTimeAtMedia fields to determine the * The client may use either the nOffset or nWallTimeAtMedia fields to determine the
* wall time until the nMediaTimestamp actually occurs. In the latter case the * wall time until the nMediaTimestamp actually occurs. In the latter case the
* client can get a more accurate value for offset by getting the current wall * client can get a more accurate value for offset by getting the current wall
* from the cloc component and subtracting it from nWallTimeAtMedia. * from the cloc component and subtracting it from nWallTimeAtMedia.
*/ */
typedef struct OMX_TIME_MEDIATIMETYPE { typedef struct OMX_TIME_MEDIATIMETYPE {
OMX_U32 nSize; /**< size of the structure in bytes */ OMX_U32 nSize; /**< size of the structure in bytes */
OMX_VERSIONTYPE nVersion; /**< OMX specification version information */ OMX_VERSIONTYPE nVersion; /**< OMX specification version information */
OMX_U32 nClientPrivate; /**< Client private data to disabiguate this media time OMX_U32 nClientPrivate; /**< Client private data to disabiguate this media time
* from others. Copied from the media time request. * from others. Copied from the media time request.
* A value of zero is reserved for time scale updates. */ * A value of zero is reserved for time scale updates. */
OMX_TIME_UPDATETYPE eUpdateType; /**< Reason for the update */ OMX_TIME_UPDATETYPE eUpdateType; /**< Reason for the update */
OMX_TICKS nMediaTimestamp; /**< Media time requested. If no media time was OMX_TICKS nMediaTimestamp; /**< Media time requested. If no media time was
* requested then this is the current media time. */ * requested then this is the current media time. */
OMX_TICKS nOffset; /**< Amount of wall clock time by which this OMX_TICKS nOffset; /**< Amount of wall clock time by which this
* request was actually fulfilled early */ * request was actually fulfilled early */
OMX_TICKS nWallTimeAtMediaTime; /**< Wall time corresponding to nMediaTimeStamp. OMX_TICKS nWallTimeAtMediaTime; /**< Wall time corresponding to nMediaTimeStamp.
* A client may compare this value to current * A client may compare this value to current
* media time obtained from the Clock Component to determine * media time obtained from the Clock Component to determine
* the wall time until the media timestamp is really * the wall time until the media timestamp is really
* current. */ * current. */
OMX_S32 xScale; /**< Current media time scale in Q16 format. */ OMX_S32 xScale; /**< Current media time scale in Q16 format. */
OMX_TIME_CLOCKSTATE eState; /* Seeking Change. Added 7/12.*/ OMX_TIME_CLOCKSTATE eState; /* Seeking Change. Added 7/12.*/
/**< State of the media time. */ /**< State of the media time. */
} OMX_TIME_MEDIATIMETYPE; } OMX_TIME_MEDIATIMETYPE;
/** Structure representing the current media time scale factor. Applicable only to clock /** Structure representing the current media time scale factor. Applicable only to clock
* component, other components see scale changes via OMX_TIME_MEDIATIMETYPE buffers sent via * component, other components see scale changes via OMX_TIME_MEDIATIMETYPE buffers sent via
* the clock component client ports. Upon recieving this config the clock component changes * the clock component client ports. Upon recieving this config the clock component changes
* the rate by which the media time increases or decreases effectively implementing trick modes. * the rate by which the media time increases or decreases effectively implementing trick modes.
*/ */
typedef struct OMX_TIME_CONFIG_SCALETYPE { typedef struct OMX_TIME_CONFIG_SCALETYPE {
OMX_U32 nSize; /**< size of the structure in bytes */ OMX_U32 nSize; /**< size of the structure in bytes */
OMX_VERSIONTYPE nVersion; /**< OMX specification version information */ OMX_VERSIONTYPE nVersion; /**< OMX specification version information */
OMX_S32 xScale; /**< This is a value in Q16 format which is used for OMX_S32 xScale; /**< This is a value in Q16 format which is used for
* scaling the media time */ * scaling the media time */
} OMX_TIME_CONFIG_SCALETYPE; } OMX_TIME_CONFIG_SCALETYPE;
/** Bits used to identify a clock port. Used in OMX_TIME_CONFIG_CLOCKSTATETYPE’s nWaitMask field */ /** Bits used to identify a clock port. Used in OMX_TIME_CONFIG_CLOCKSTATETYPE’s nWaitMask field */
#define OMX_CLOCKPORT0 0x00000001 #define OMX_CLOCKPORT0 0x00000001
#define OMX_CLOCKPORT1 0x00000002 #define OMX_CLOCKPORT1 0x00000002
#define OMX_CLOCKPORT2 0x00000004 #define OMX_CLOCKPORT2 0x00000004
#define OMX_CLOCKPORT3 0x00000008 #define OMX_CLOCKPORT3 0x00000008
#define OMX_CLOCKPORT4 0x00000010 #define OMX_CLOCKPORT4 0x00000010
#define OMX_CLOCKPORT5 0x00000020 #define OMX_CLOCKPORT5 0x00000020
#define OMX_CLOCKPORT6 0x00000040 #define OMX_CLOCKPORT6 0x00000040
#define OMX_CLOCKPORT7 0x00000080 #define OMX_CLOCKPORT7 0x00000080
/** Structure representing the current mode of the media clock. /** Structure representing the current mode of the media clock.
* IL Client uses this config to change or query the mode of the * IL Client uses this config to change or query the mode of the
* media clock of the clock component. Applicable only to clock * media clock of the clock component. Applicable only to clock
* component. * component.
* *
* On a SetConfig if eState is OMX_TIME_ClockStateRunning media time * On a SetConfig if eState is OMX_TIME_ClockStateRunning media time
* starts immediately at the prescribed start time. If * starts immediately at the prescribed start time. If
* OMX_TIME_ClockStateWaitingForStartTime the Clock Component ignores * OMX_TIME_ClockStateWaitingForStartTime the Clock Component ignores
* the given nStartTime and waits for all clients specified in the * the given nStartTime and waits for all clients specified in the
* nWaitMask to send starttimes (via * nWaitMask to send starttimes (via
* OMX_IndexConfigTimeClientStartTime). The Clock Component then starts * OMX_IndexConfigTimeClientStartTime). The Clock Component then starts
* the media clock using the earliest start time supplied. */ * the media clock using the earliest start time supplied. */
typedef struct OMX_TIME_CONFIG_CLOCKSTATETYPE { typedef struct OMX_TIME_CONFIG_CLOCKSTATETYPE {
OMX_U32 nSize; /**< size of the structure in bytes */ OMX_U32 nSize; /**< size of the structure in bytes */
OMX_VERSIONTYPE nVersion; /**< OMX specification version OMX_VERSIONTYPE nVersion; /**< OMX specification version
* information */ * information */
OMX_TIME_CLOCKSTATE eState; /**< State of the media time. */ OMX_TIME_CLOCKSTATE eState; /**< State of the media time. */
OMX_TICKS nStartTime; /**< Start time of the media time. */ OMX_TICKS nStartTime; /**< Start time of the media time. */
OMX_TICKS nOffset; /**< Time to offset the media time by OMX_TICKS nOffset; /**< Time to offset the media time by
* (e.g. preroll). Media time will be * (e.g. preroll). Media time will be
* reported to be nOffset ticks earlier. * reported to be nOffset ticks earlier.
*/ */
OMX_U32 nWaitMask; /**< Mask of OMX_CLOCKPORT values. */ OMX_U32 nWaitMask; /**< Mask of OMX_CLOCKPORT values. */
} OMX_TIME_CONFIG_CLOCKSTATETYPE; } OMX_TIME_CONFIG_CLOCKSTATETYPE;
/** Structure representing the reference clock currently being used to /** Structure representing the reference clock currently being used to
* compute media time. IL client uses this config to change or query the * compute media time. IL client uses this config to change or query the
* clock component's active reference clock */ * clock component's active reference clock */
typedef struct OMX_TIME_CONFIG_ACTIVEREFCLOCKTYPE { typedef struct OMX_TIME_CONFIG_ACTIVEREFCLOCKTYPE {
OMX_U32 nSize; /**< size of the structure in bytes */ OMX_U32 nSize; /**< size of the structure in bytes */
OMX_VERSIONTYPE nVersion; /**< OMX specification version information */ OMX_VERSIONTYPE nVersion; /**< OMX specification version information */
OMX_TIME_REFCLOCKTYPE eClock; /**< Reference clock used to compute media time */ OMX_TIME_REFCLOCKTYPE eClock; /**< Reference clock used to compute media time */
} OMX_TIME_CONFIG_ACTIVEREFCLOCKTYPE; } OMX_TIME_CONFIG_ACTIVEREFCLOCKTYPE;
/** Descriptor for setting specifics of power type. /** Descriptor for setting specifics of power type.
* Note: this structure is listed for backwards compatibility. */ * Note: this structure is listed for backwards compatibility. */
typedef struct OMX_OTHER_CONFIG_POWERTYPE { typedef struct OMX_OTHER_CONFIG_POWERTYPE {
OMX_U32 nSize; /**< size of the structure in bytes */ OMX_U32 nSize; /**< size of the structure in bytes */
OMX_VERSIONTYPE nVersion; /**< OMX specification version information */ OMX_VERSIONTYPE nVersion; /**< OMX specification version information */
OMX_BOOL bEnablePM; /**< Flag to enable Power Management */ OMX_BOOL bEnablePM; /**< Flag to enable Power Management */
} OMX_OTHER_CONFIG_POWERTYPE; } OMX_OTHER_CONFIG_POWERTYPE;
/** Descriptor for setting specifics of stats type. /** Descriptor for setting specifics of stats type.
* Note: this structure is listed for backwards compatibility. */ * Note: this structure is listed for backwards compatibility. */
typedef struct OMX_OTHER_CONFIG_STATSTYPE { typedef struct OMX_OTHER_CONFIG_STATSTYPE {
OMX_U32 nSize; /**< size of the structure in bytes */ OMX_U32 nSize; /**< size of the structure in bytes */
OMX_VERSIONTYPE nVersion; /**< OMX specification version information */ OMX_VERSIONTYPE nVersion; /**< OMX specification version information */
/* what goes here */ /* what goes here */
} OMX_OTHER_CONFIG_STATSTYPE; } OMX_OTHER_CONFIG_STATSTYPE;
/** /**
* The PortDefinition structure is used to define all of the parameters * The PortDefinition structure is used to define all of the parameters
* necessary for the compliant component to setup an input or an output other * necessary for the compliant component to setup an input or an output other
* path. * path.
*/ */
typedef struct OMX_OTHER_PORTDEFINITIONTYPE { typedef struct OMX_OTHER_PORTDEFINITIONTYPE {
OMX_OTHER_FORMATTYPE eFormat; /**< Type of data expected for this channel */ OMX_OTHER_FORMATTYPE eFormat; /**< Type of data expected for this channel */
} OMX_OTHER_PORTDEFINITIONTYPE; } OMX_OTHER_PORTDEFINITIONTYPE;
/** Port format parameter. This structure is used to enumerate /** Port format parameter. This structure is used to enumerate
* the various data input/output format supported by the port. * the various data input/output format supported by the port.
*/ */
typedef struct OMX_OTHER_PARAM_PORTFORMATTYPE { typedef struct OMX_OTHER_PARAM_PORTFORMATTYPE {
OMX_U32 nSize; /**< size of the structure in bytes */ OMX_U32 nSize; /**< size of the structure in bytes */
OMX_VERSIONTYPE nVersion; /**< OMX specification version information */ OMX_VERSIONTYPE nVersion; /**< OMX specification version information */
OMX_U32 nPortIndex; /**< Indicates which port to set */ OMX_U32 nPortIndex; /**< Indicates which port to set */
OMX_U32 nIndex; /**< Indicates the enumeration index for the format from 0x0 to N-1 */ OMX_U32 nIndex; /**< Indicates the enumeration index for the format from 0x0 to N-1 */
OMX_OTHER_FORMATTYPE eFormat; /**< Type of data expected for this channel */ OMX_OTHER_FORMATTYPE eFormat; /**< Type of data expected for this channel */
} OMX_OTHER_PARAM_PORTFORMATTYPE; } OMX_OTHER_PARAM_PORTFORMATTYPE;
#ifdef __cplusplus #ifdef __cplusplus
} }
#endif /* __cplusplus */ #endif /* __cplusplus */
#endif #endif
/* File EOF */ /* File EOF */
/* /*
* Copyright (c) 2008 The Khronos Group Inc. * Copyright (c) 2008 The Khronos Group Inc.
* *
* Permission is hereby granted, free of charge, to any person obtaining * Permission is hereby granted, free of charge, to any person obtaining
* a copy of this software and associated documentation files (the * a copy of this software and associated documentation files (the
* "Software"), to deal in the Software without restriction, including * "Software"), to deal in the Software without restriction, including
* without limitation the rights to use, copy, modify, merge, publish, * without limitation the rights to use, copy, modify, merge, publish,
* distribute, sublicense, and/or sell copies of the Software, and to * distribute, sublicense, and/or sell copies of the Software, and to
* permit persons to whom the Software is furnished to do so, subject * permit persons to whom the Software is furnished to do so, subject
* to the following conditions: * to the following conditions:
* The above copyright notice and this permission notice shall be included * The above copyright notice and this permission notice shall be included
* in all copies or substantial portions of the Software. * in all copies or substantial portions of the Software.
* *
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
* OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, * CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
* *
*/ */
/** OMX_Types.h - OpenMax IL version 1.1.2 /** OMX_Types.h - OpenMax IL version 1.1.2
* The OMX_Types header file contains the primitive type definitions used by * The OMX_Types header file contains the primitive type definitions used by
* the core, the application and the component. This file may need to be * the core, the application and the component. This file may need to be
* modified to be used on systems that do not have "char" set to 8 bits, * modified to be used on systems that do not have "char" set to 8 bits,
* "short" set to 16 bits and "long" set to 32 bits. * "short" set to 16 bits and "long" set to 32 bits.
*/ */
#ifndef OMX_Types_h #ifndef OMX_Types_h
#define OMX_Types_h #define OMX_Types_h
#ifdef __cplusplus #ifdef __cplusplus
extern "C" { extern "C" {
#endif /* __cplusplus */ #endif /* __cplusplus */
/** The OMX_API and OMX_APIENTRY are platform specific definitions used /** The OMX_API and OMX_APIENTRY are platform specific definitions used
* to declare OMX function prototypes. They are modified to meet the * to declare OMX function prototypes. They are modified to meet the
* requirements for a particular platform */ * requirements for a particular platform */
#ifdef __SYMBIAN32__ #ifdef __SYMBIAN32__
# ifdef __OMX_EXPORTS # ifdef __OMX_EXPORTS
# define OMX_API __declspec(dllexport) # define OMX_API __declspec(dllexport)
# else # else
# ifdef _WIN32 # ifdef _WIN32
# define OMX_API __declspec(dllexport) # define OMX_API __declspec(dllexport)
# else # else
# define OMX_API __declspec(dllimport) # define OMX_API __declspec(dllimport)
# endif # endif
# endif # endif
#else #else
# ifdef _WIN32 # ifdef _WIN32
# ifdef __OMX_EXPORTS # ifdef __OMX_EXPORTS
# define OMX_API __declspec(dllexport) # define OMX_API __declspec(dllexport)
# else # else
# define OMX_API __declspec(dllimport) # define OMX_API __declspec(dllimport)
# endif # endif
# else # else
# ifdef __OMX_EXPORTS # ifdef __OMX_EXPORTS
# define OMX_API # define OMX_API
# else # else
# define OMX_API extern # define OMX_API extern
# endif # endif
# endif # endif
#endif #endif
#ifndef OMX_APIENTRY #ifndef OMX_APIENTRY
#define OMX_APIENTRY #define OMX_APIENTRY
#endif #endif
/** OMX_IN is used to identify inputs to an OMX function. This designation /** OMX_IN is used to identify inputs to an OMX function. This designation
will also be used in the case of a pointer that points to a parameter will also be used in the case of a pointer that points to a parameter
that is used as an output. */ that is used as an output. */
#ifndef OMX_IN #ifndef OMX_IN
#define OMX_IN #define OMX_IN
#endif #endif
/** OMX_OUT is used to identify outputs from an OMX function. This /** OMX_OUT is used to identify outputs from an OMX function. This
designation will also be used in the case of a pointer that points designation will also be used in the case of a pointer that points
to a parameter that is used as an input. */ to a parameter that is used as an input. */
#ifndef OMX_OUT #ifndef OMX_OUT
#define OMX_OUT #define OMX_OUT
#endif #endif
/** OMX_INOUT is used to identify parameters that may be either inputs or /** OMX_INOUT is used to identify parameters that may be either inputs or
outputs from an OMX function at the same time. This designation will outputs from an OMX function at the same time. This designation will
also be used in the case of a pointer that points to a parameter that also be used in the case of a pointer that points to a parameter that
is used both as an input and an output. */ is used both as an input and an output. */
#ifndef OMX_INOUT #ifndef OMX_INOUT
#define OMX_INOUT #define OMX_INOUT
#endif #endif
/** OMX_ALL is used to as a wildcard to select all entities of the same type /** OMX_ALL is used to as a wildcard to select all entities of the same type
* when specifying the index, or referring to a object by an index. (i.e. * when specifying the index, or referring to a object by an index. (i.e.
* use OMX_ALL to indicate all N channels). When used as a port index * use OMX_ALL to indicate all N channels). When used as a port index
* for a config or parameter this OMX_ALL denotes that the config or * for a config or parameter this OMX_ALL denotes that the config or
* parameter applies to the entire component not just one port. */ * parameter applies to the entire component not just one port. */
#define OMX_ALL 0xFFFFFFFF #define OMX_ALL 0xFFFFFFFF
/** In the following we define groups that help building doxygen documentation */ /** In the following we define groups that help building doxygen documentation */
/** @defgroup core OpenMAX IL core /** @defgroup core OpenMAX IL core
* Functions and structure related to the OMX IL core * Functions and structure related to the OMX IL core
*/ */
/** @defgroup comp OpenMAX IL component /** @defgroup comp OpenMAX IL component
* Functions and structure related to the OMX IL component * Functions and structure related to the OMX IL component
*/ */
/** @defgroup rpm Resource and Policy Management /** @defgroup rpm Resource and Policy Management
* Structures for resource and policy management of components * Structures for resource and policy management of components
*/ */
/** @defgroup buf Buffer Management /** @defgroup buf Buffer Management
* Buffer handling functions and structures * Buffer handling functions and structures
*/ */
/** @defgroup tun Tunneling /** @defgroup tun Tunneling
* @ingroup core comp * @ingroup core comp
* Structures and functions to manage tunnels among component ports * Structures and functions to manage tunnels among component ports
*/ */
/** @defgroup cp Content Pipes /** @defgroup cp Content Pipes
* @ingroup core * @ingroup core
*/ */
/** @defgroup metadata Metadata handling /** @defgroup metadata Metadata handling
* *
*/ */
/** OMX_U8 is an 8 bit unsigned quantity that is byte aligned */ /** OMX_U8 is an 8 bit unsigned quantity that is byte aligned */
typedef unsigned char OMX_U8; typedef unsigned char OMX_U8;
/** OMX_S8 is an 8 bit signed quantity that is byte aligned */ /** OMX_S8 is an 8 bit signed quantity that is byte aligned */
typedef signed char OMX_S8; typedef signed char OMX_S8;
/** OMX_U16 is a 16 bit unsigned quantity that is 16 bit word aligned */ /** OMX_U16 is a 16 bit unsigned quantity that is 16 bit word aligned */
typedef unsigned short OMX_U16; typedef unsigned short OMX_U16;
/** OMX_S16 is a 16 bit signed quantity that is 16 bit word aligned */ /** OMX_S16 is a 16 bit signed quantity that is 16 bit word aligned */
typedef signed short OMX_S16; typedef signed short OMX_S16;
/** OMX_U32 is a 32 bit unsigned quantity that is 32 bit word aligned */ /** OMX_U32 is a 32 bit unsigned quantity that is 32 bit word aligned */
typedef unsigned long OMX_U32; typedef unsigned long OMX_U32;
/** OMX_S32 is a 32 bit signed quantity that is 32 bit word aligned */ /** OMX_S32 is a 32 bit signed quantity that is 32 bit word aligned */
typedef signed long OMX_S32; typedef signed long OMX_S32;
/* Users with compilers that cannot accept the "long long" designation should /* Users with compilers that cannot accept the "long long" designation should
define the OMX_SKIP64BIT macro. It should be noted that this may cause define the OMX_SKIP64BIT macro. It should be noted that this may cause
some components to fail to compile if the component was written to require some components to fail to compile if the component was written to require
64 bit integral types. However, these components would NOT compile anyway 64 bit integral types. However, these components would NOT compile anyway
since the compiler does not support the way the component was written. since the compiler does not support the way the component was written.
*/ */
#ifndef OMX_SKIP64BIT #ifndef OMX_SKIP64BIT
#ifdef __SYMBIAN32__ #ifdef __SYMBIAN32__
/** OMX_U64 is a 64 bit unsigned quantity that is 64 bit word aligned */ /** OMX_U64 is a 64 bit unsigned quantity that is 64 bit word aligned */
typedef unsigned long long OMX_U64; typedef unsigned long long OMX_U64;
/** OMX_S64 is a 64 bit signed quantity that is 64 bit word aligned */ /** OMX_S64 is a 64 bit signed quantity that is 64 bit word aligned */
typedef signed long long OMX_S64; typedef signed long long OMX_S64;
#elif defined(WIN32) #elif defined(WIN32)
/** OMX_U64 is a 64 bit unsigned quantity that is 64 bit word aligned */ /** OMX_U64 is a 64 bit unsigned quantity that is 64 bit word aligned */
typedef unsigned __int64 OMX_U64; typedef unsigned __int64 OMX_U64;
/** OMX_S64 is a 64 bit signed quantity that is 64 bit word aligned */ /** OMX_S64 is a 64 bit signed quantity that is 64 bit word aligned */
typedef signed __int64 OMX_S64; typedef signed __int64 OMX_S64;
#else /* WIN32 */ #else /* WIN32 */
/** OMX_U64 is a 64 bit unsigned quantity that is 64 bit word aligned */ /** OMX_U64 is a 64 bit unsigned quantity that is 64 bit word aligned */
typedef unsigned long long OMX_U64; typedef unsigned long long OMX_U64;
/** OMX_S64 is a 64 bit signed quantity that is 64 bit word aligned */ /** OMX_S64 is a 64 bit signed quantity that is 64 bit word aligned */
typedef signed long long OMX_S64; typedef signed long long OMX_S64;
#endif /* WIN32 */ #endif /* WIN32 */
#endif #endif
/** The OMX_BOOL type is intended to be used to represent a true or a false /** The OMX_BOOL type is intended to be used to represent a true or a false
value when passing parameters to and from the OMX core and components. The value when passing parameters to and from the OMX core and components. The
OMX_BOOL is a 32 bit quantity and is aligned on a 32 bit word boundary. OMX_BOOL is a 32 bit quantity and is aligned on a 32 bit word boundary.
*/ */
typedef enum OMX_BOOL { typedef enum OMX_BOOL {
OMX_FALSE = 0, OMX_FALSE = 0,
OMX_TRUE = !OMX_FALSE, OMX_TRUE = !OMX_FALSE,
OMX_BOOL_MAX = 0x7FFFFFFF OMX_BOOL_MAX = 0x7FFFFFFF
} OMX_BOOL; } OMX_BOOL;
/** The OMX_PTR type is intended to be used to pass pointers between the OMX /** The OMX_PTR type is intended to be used to pass pointers between the OMX
applications and the OMX Core and components. This is a 32 bit pointer and applications and the OMX Core and components. This is a 32 bit pointer and
is aligned on a 32 bit boundary. is aligned on a 32 bit boundary.
*/ */
typedef void* OMX_PTR; typedef void* OMX_PTR;
/** The OMX_STRING type is intended to be used to pass "C" type strings between /** The OMX_STRING type is intended to be used to pass "C" type strings between
the application and the core and component. The OMX_STRING type is a 32 the application and the core and component. The OMX_STRING type is a 32
bit pointer to a zero terminated string. The pointer is word aligned and bit pointer to a zero terminated string. The pointer is word aligned and
the string is byte aligned. the string is byte aligned.
*/ */
typedef char* OMX_STRING; typedef char* OMX_STRING;
/** The OMX_BYTE type is intended to be used to pass arrays of bytes such as /** The OMX_BYTE type is intended to be used to pass arrays of bytes such as
buffers between the application and the component and core. The OMX_BYTE buffers between the application and the component and core. The OMX_BYTE
type is a 32 bit pointer to a zero terminated string. The pointer is word type is a 32 bit pointer to a zero terminated string. The pointer is word
aligned and the string is byte aligned. aligned and the string is byte aligned.
*/ */
typedef unsigned char* OMX_BYTE; typedef unsigned char* OMX_BYTE;
/** OMX_UUIDTYPE is a very long unique identifier to uniquely identify /** OMX_UUIDTYPE is a very long unique identifier to uniquely identify
at runtime. This identifier should be generated by a component in a way at runtime. This identifier should be generated by a component in a way
that guarantees that every instance of the identifier running on the system that guarantees that every instance of the identifier running on the system
is unique. */ is unique. */
typedef unsigned char OMX_UUIDTYPE[128]; typedef unsigned char OMX_UUIDTYPE[128];
/** The OMX_DIRTYPE enumeration is used to indicate if a port is an input or /** The OMX_DIRTYPE enumeration is used to indicate if a port is an input or
an output port. This enumeration is common across all component types. an output port. This enumeration is common across all component types.
*/ */
typedef enum OMX_DIRTYPE typedef enum OMX_DIRTYPE
{ {
OMX_DirInput, /**< Port is an input port */ OMX_DirInput, /**< Port is an input port */
OMX_DirOutput, /**< Port is an output port */ OMX_DirOutput, /**< Port is an output port */
OMX_DirMax = 0x7FFFFFFF OMX_DirMax = 0x7FFFFFFF
} OMX_DIRTYPE; } OMX_DIRTYPE;
/** The OMX_ENDIANTYPE enumeration is used to indicate the bit ordering /** The OMX_ENDIANTYPE enumeration is used to indicate the bit ordering
for numerical data (i.e. big endian, or little endian). for numerical data (i.e. big endian, or little endian).
*/ */
typedef enum OMX_ENDIANTYPE typedef enum OMX_ENDIANTYPE
{ {
OMX_EndianBig, /**< big endian */ OMX_EndianBig, /**< big endian */
OMX_EndianLittle, /**< little endian */ OMX_EndianLittle, /**< little endian */
OMX_EndianMax = 0x7FFFFFFF OMX_EndianMax = 0x7FFFFFFF
} OMX_ENDIANTYPE; } OMX_ENDIANTYPE;
/** The OMX_NUMERICALDATATYPE enumeration is used to indicate if data /** The OMX_NUMERICALDATATYPE enumeration is used to indicate if data
is signed or unsigned is signed or unsigned
*/ */
typedef enum OMX_NUMERICALDATATYPE typedef enum OMX_NUMERICALDATATYPE
{ {
OMX_NumericalDataSigned, /**< signed data */ OMX_NumericalDataSigned, /**< signed data */
OMX_NumericalDataUnsigned, /**< unsigned data */ OMX_NumericalDataUnsigned, /**< unsigned data */
OMX_NumercialDataMax = 0x7FFFFFFF OMX_NumercialDataMax = 0x7FFFFFFF
} OMX_NUMERICALDATATYPE; } OMX_NUMERICALDATATYPE;
/** Unsigned bounded value type */ /** Unsigned bounded value type */
typedef struct OMX_BU32 { typedef struct OMX_BU32 {
OMX_U32 nValue; /**< actual value */ OMX_U32 nValue; /**< actual value */
OMX_U32 nMin; /**< minimum for value (i.e. nValue >= nMin) */ OMX_U32 nMin; /**< minimum for value (i.e. nValue >= nMin) */
OMX_U32 nMax; /**< maximum for value (i.e. nValue <= nMax) */ OMX_U32 nMax; /**< maximum for value (i.e. nValue <= nMax) */
} OMX_BU32; } OMX_BU32;
/** Signed bounded value type */ /** Signed bounded value type */
typedef struct OMX_BS32 { typedef struct OMX_BS32 {
OMX_S32 nValue; /**< actual value */ OMX_S32 nValue; /**< actual value */
OMX_S32 nMin; /**< minimum for value (i.e. nValue >= nMin) */ OMX_S32 nMin; /**< minimum for value (i.e. nValue >= nMin) */
OMX_S32 nMax; /**< maximum for value (i.e. nValue <= nMax) */ OMX_S32 nMax; /**< maximum for value (i.e. nValue <= nMax) */
} OMX_BS32; } OMX_BS32;
/** Structure representing some time or duration in microseconds. This structure /** Structure representing some time or duration in microseconds. This structure
* must be interpreted as a signed 64 bit value. The quantity is signed to accommodate * must be interpreted as a signed 64 bit value. The quantity is signed to accommodate
* negative deltas and preroll scenarios. The quantity is represented in microseconds * negative deltas and preroll scenarios. The quantity is represented in microseconds
* to accomodate high resolution timestamps (e.g. DVD presentation timestamps based * to accomodate high resolution timestamps (e.g. DVD presentation timestamps based
* on a 90kHz clock) and to allow more accurate and synchronized delivery (e.g. * on a 90kHz clock) and to allow more accurate and synchronized delivery (e.g.
* individual audio samples delivered at 192 kHz). The quantity is 64 bit to * individual audio samples delivered at 192 kHz). The quantity is 64 bit to
* accommodate a large dynamic range (signed 32 bit values would allow only for plus * accommodate a large dynamic range (signed 32 bit values would allow only for plus
* or minus 35 minutes). * or minus 35 minutes).
* *
* Implementations with limited precision may convert the signed 64 bit value to * Implementations with limited precision may convert the signed 64 bit value to
* a signed 32 bit value internally but risk loss of precision. * a signed 32 bit value internally but risk loss of precision.
*/ */
#ifndef OMX_SKIP64BIT #ifndef OMX_SKIP64BIT
typedef OMX_S64 OMX_TICKS; typedef OMX_S64 OMX_TICKS;
#else #else
typedef struct OMX_TICKS typedef struct OMX_TICKS
{ {
OMX_U32 nLowPart; /** low bits of the signed 64 bit tick value */ OMX_U32 nLowPart; /** low bits of the signed 64 bit tick value */
OMX_U32 nHighPart; /** high bits of the signed 64 bit tick value */ OMX_U32 nHighPart; /** high bits of the signed 64 bit tick value */
} OMX_TICKS; } OMX_TICKS;
#endif #endif
#define OMX_TICKS_PER_SECOND 1000000 #define OMX_TICKS_PER_SECOND 1000000
/** Define the public interface for the OMX Handle. The core will not use /** Define the public interface for the OMX Handle. The core will not use
this value internally, but the application should only use this value. this value internally, but the application should only use this value.
*/ */
typedef void* OMX_HANDLETYPE; typedef void* OMX_HANDLETYPE;
typedef struct OMX_MARKTYPE typedef struct OMX_MARKTYPE
{ {
OMX_HANDLETYPE hMarkTargetComponent; /**< The component that will OMX_HANDLETYPE hMarkTargetComponent; /**< The component that will
generate a mark event upon generate a mark event upon
processing the mark. */ processing the mark. */
OMX_PTR pMarkData; /**< Application specific data associated with OMX_PTR pMarkData; /**< Application specific data associated with
the mark sent on a mark event to disambiguate the mark sent on a mark event to disambiguate
this mark from others. */ this mark from others. */
} OMX_MARKTYPE; } OMX_MARKTYPE;
/** OMX_NATIVE_DEVICETYPE is used to map a OMX video port to the /** OMX_NATIVE_DEVICETYPE is used to map a OMX video port to the
* platform & operating specific object used to reference the display * platform & operating specific object used to reference the display
* or can be used by a audio port for native audio rendering */ * or can be used by a audio port for native audio rendering */
typedef void* OMX_NATIVE_DEVICETYPE; typedef void* OMX_NATIVE_DEVICETYPE;
/** OMX_NATIVE_WINDOWTYPE is used to map a OMX video port to the /** OMX_NATIVE_WINDOWTYPE is used to map a OMX video port to the
* platform & operating specific object used to reference the window */ * platform & operating specific object used to reference the window */
typedef void* OMX_NATIVE_WINDOWTYPE; typedef void* OMX_NATIVE_WINDOWTYPE;
/** The OMX_VERSIONTYPE union is used to specify the version for /** The OMX_VERSIONTYPE union is used to specify the version for
a structure or component. For a component, the version is entirely a structure or component. For a component, the version is entirely
specified by the component vendor. Components doing the same function specified by the component vendor. Components doing the same function
from different vendors may or may not have the same version. For from different vendors may or may not have the same version. For
structures, the version shall be set by the entity that allocates the structures, the version shall be set by the entity that allocates the
structure. For structures specified in the OMX 1.1 specification, the structure. For structures specified in the OMX 1.1 specification, the
value of the version shall be set to 1.1.0.0 in all cases. Access to the value of the version shall be set to 1.1.0.0 in all cases. Access to the
OMX_VERSIONTYPE can be by a single 32 bit access (e.g. by nVersion) or OMX_VERSIONTYPE can be by a single 32 bit access (e.g. by nVersion) or
by accessing one of the structure elements to, for example, check only by accessing one of the structure elements to, for example, check only
the Major revision. the Major revision.
*/ */
typedef union OMX_VERSIONTYPE typedef union OMX_VERSIONTYPE
{ {
struct struct
{ {
OMX_U8 nVersionMajor; /**< Major version accessor element */ OMX_U8 nVersionMajor; /**< Major version accessor element */
OMX_U8 nVersionMinor; /**< Minor version accessor element */ OMX_U8 nVersionMinor; /**< Minor version accessor element */
OMX_U8 nRevision; /**< Revision version accessor element */ OMX_U8 nRevision; /**< Revision version accessor element */
OMX_U8 nStep; /**< Step version accessor element */ OMX_U8 nStep; /**< Step version accessor element */
} s; } s;
OMX_U32 nVersion; /**< 32 bit value to make accessing the OMX_U32 nVersion; /**< 32 bit value to make accessing the
version easily done in a single word version easily done in a single word
size copy/compare operation */ size copy/compare operation */
} OMX_VERSIONTYPE; } OMX_VERSIONTYPE;
#ifdef __cplusplus #ifdef __cplusplus
} }
#endif /* __cplusplus */ #endif /* __cplusplus */
#endif #endif
/* File EOF */ /* File EOF */
/** /**
* Copyright (c) 2008 The Khronos Group Inc. * Copyright (c) 2008 The Khronos Group Inc.
* *
* Permission is hereby granted, free of charge, to any person obtaining * Permission is hereby granted, free of charge, to any person obtaining
* a copy of this software and associated documentation files (the * a copy of this software and associated documentation files (the
* "Software"), to deal in the Software without restriction, including * "Software"), to deal in the Software without restriction, including
* without limitation the rights to use, copy, modify, merge, publish, * without limitation the rights to use, copy, modify, merge, publish,
* distribute, sublicense, and/or sell copies of the Software, and to * distribute, sublicense, and/or sell copies of the Software, and to
* permit persons to whom the Software is furnished to do so, subject * permit persons to whom the Software is furnished to do so, subject
* to the following conditions: * to the following conditions:
* The above copyright notice and this permission notice shall be included * The above copyright notice and this permission notice shall be included
* in all copies or substantial portions of the Software. * in all copies or substantial portions of the Software.
* *
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
* OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, * CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
* *
*/ */
/** /**
* @file OMX_Video.h - OpenMax IL version 1.1.2 * @file OMX_Video.h - OpenMax IL version 1.1.2
* The structures is needed by Video components to exchange parameters * The structures is needed by Video components to exchange parameters
* and configuration data with OMX components. * and configuration data with OMX components.
*/ */
#ifndef OMX_Video_h #ifndef OMX_Video_h
#define OMX_Video_h #define OMX_Video_h
/** @defgroup video OpenMAX IL Video Domain /** @defgroup video OpenMAX IL Video Domain
* @ingroup iv * @ingroup iv
* Structures for OpenMAX IL Video domain * Structures for OpenMAX IL Video domain
* @{ * @{
*/ */
#ifdef __cplusplus #ifdef __cplusplus
extern "C" { extern "C" {
#endif /* __cplusplus */ #endif /* __cplusplus */
/** /**
* Each OMX header must include all required header files to allow the * Each OMX header must include all required header files to allow the
* header to compile without errors. The includes below are required * header to compile without errors. The includes below are required
* for this header file to compile successfully * for this header file to compile successfully
*/ */
#include <OMX_IVCommon.h> #include <OMX_IVCommon.h>
/** /**
* Enumeration used to define the possible video compression codings. * Enumeration used to define the possible video compression codings.
* NOTE: This essentially refers to file extensions. If the coding is * NOTE: This essentially refers to file extensions. If the coding is
* being used to specify the ENCODE type, then additional work * being used to specify the ENCODE type, then additional work
* must be done to configure the exact flavor of the compression * must be done to configure the exact flavor of the compression
* to be used. For decode cases where the user application can * to be used. For decode cases where the user application can
* not differentiate between MPEG-4 and H.264 bit streams, it is * not differentiate between MPEG-4 and H.264 bit streams, it is
* up to the codec to handle this. * up to the codec to handle this.
*/ */
typedef enum OMX_VIDEO_CODINGTYPE { typedef enum OMX_VIDEO_CODINGTYPE {
OMX_VIDEO_CodingUnused, /**< Value when coding is N/A */ OMX_VIDEO_CodingUnused, /**< Value when coding is N/A */
OMX_VIDEO_CodingAutoDetect, /**< Autodetection of coding type */ OMX_VIDEO_CodingAutoDetect, /**< Autodetection of coding type */
OMX_VIDEO_CodingMPEG2, /**< AKA: H.262 */ OMX_VIDEO_CodingMPEG2, /**< AKA: H.262 */
OMX_VIDEO_CodingH263, /**< H.263 */ OMX_VIDEO_CodingH263, /**< H.263 */
OMX_VIDEO_CodingMPEG4, /**< MPEG-4 */ OMX_VIDEO_CodingMPEG4, /**< MPEG-4 */
OMX_VIDEO_CodingWMV, /**< all versions of Windows Media Video */ OMX_VIDEO_CodingWMV, /**< all versions of Windows Media Video */
OMX_VIDEO_CodingRV, /**< all versions of Real Video */ OMX_VIDEO_CodingRV, /**< all versions of Real Video */
OMX_VIDEO_CodingAVC, /**< H.264/AVC */ OMX_VIDEO_CodingAVC, /**< H.264/AVC */
OMX_VIDEO_CodingMJPEG, /**< Motion JPEG */ OMX_VIDEO_CodingMJPEG, /**< Motion JPEG */
OMX_VIDEO_CodingKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */ OMX_VIDEO_CodingKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */
OMX_VIDEO_CodingVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */ OMX_VIDEO_CodingVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */
OMX_VIDEO_CodingMax = 0x7FFFFFFF OMX_VIDEO_CodingMax = 0x7FFFFFFF
} OMX_VIDEO_CODINGTYPE; } OMX_VIDEO_CODINGTYPE;
/** /**
* Data structure used to define a video path. The number of Video paths for * Data structure used to define a video path. The number of Video paths for
* input and output will vary by type of the Video component. * input and output will vary by type of the Video component.
* *
* Input (aka Source) : zero Inputs, one Output, * Input (aka Source) : zero Inputs, one Output,
* Splitter : one Input, 2 or more Outputs, * Splitter : one Input, 2 or more Outputs,
* Processing Element : one Input, one output, * Processing Element : one Input, one output,
* Mixer : 2 or more inputs, one output, * Mixer : 2 or more inputs, one output,
* Output (aka Sink) : one Input, zero outputs. * Output (aka Sink) : one Input, zero outputs.
* *
* The PortDefinition structure is used to define all of the parameters * The PortDefinition structure is used to define all of the parameters
* necessary for the compliant component to setup an input or an output video * necessary for the compliant component to setup an input or an output video
* path. If additional vendor specific data is required, it should be * path. If additional vendor specific data is required, it should be
* transmitted to the component using the CustomCommand function. Compliant * transmitted to the component using the CustomCommand function. Compliant
* components will prepopulate this structure with optimal values during the * components will prepopulate this structure with optimal values during the
* GetDefaultInitParams command. * GetDefaultInitParams command.
* *
* STRUCT MEMBERS: * STRUCT MEMBERS:
* cMIMEType : MIME type of data for the port * cMIMEType : MIME type of data for the port
* pNativeRender : Platform specific reference for a display if a * pNativeRender : Platform specific reference for a display if a
* sync, otherwise this field is 0 * sync, otherwise this field is 0
* nFrameWidth : Width of frame to be used on channel if * nFrameWidth : Width of frame to be used on channel if
* uncompressed format is used. Use 0 for unknown, * uncompressed format is used. Use 0 for unknown,
* don't care or variable * don't care or variable
* nFrameHeight : Height of frame to be used on channel if * nFrameHeight : Height of frame to be used on channel if
* uncompressed format is used. Use 0 for unknown, * uncompressed format is used. Use 0 for unknown,
* don't care or variable * don't care or variable
* nStride : Number of bytes per span of an image * nStride : Number of bytes per span of an image
* (i.e. indicates the number of bytes to get * (i.e. indicates the number of bytes to get
* from span N to span N+1, where negative stride * from span N to span N+1, where negative stride
* indicates the image is bottom up * indicates the image is bottom up
* nSliceHeight : Height used when encoding in slices * nSliceHeight : Height used when encoding in slices
* nBitrate : Bit rate of frame to be used on channel if * nBitrate : Bit rate of frame to be used on channel if
* compressed format is used. Use 0 for unknown, * compressed format is used. Use 0 for unknown,
* don't care or variable * don't care or variable
* xFramerate : Frame rate to be used on channel if uncompressed * xFramerate : Frame rate to be used on channel if uncompressed
* format is used. Use 0 for unknown, don't care or * format is used. Use 0 for unknown, don't care or
* variable. Units are Q16 frames per second. * variable. Units are Q16 frames per second.
* bFlagErrorConcealment : Turns on error concealment if it is supported by * bFlagErrorConcealment : Turns on error concealment if it is supported by
* the OMX component * the OMX component
* eCompressionFormat : Compression format used in this instance of the * eCompressionFormat : Compression format used in this instance of the
* component. When OMX_VIDEO_CodingUnused is * component. When OMX_VIDEO_CodingUnused is
* specified, eColorFormat is used * specified, eColorFormat is used
* eColorFormat : Decompressed format used by this component * eColorFormat : Decompressed format used by this component
* pNativeWindow : Platform specific reference for a window object if a * pNativeWindow : Platform specific reference for a window object if a
* display sink , otherwise this field is 0x0. * display sink , otherwise this field is 0x0.
*/ */
typedef struct OMX_VIDEO_PORTDEFINITIONTYPE { typedef struct OMX_VIDEO_PORTDEFINITIONTYPE {
OMX_STRING cMIMEType; OMX_STRING cMIMEType;
OMX_NATIVE_DEVICETYPE pNativeRender; OMX_NATIVE_DEVICETYPE pNativeRender;
OMX_U32 nFrameWidth; OMX_U32 nFrameWidth;
OMX_U32 nFrameHeight; OMX_U32 nFrameHeight;
OMX_S32 nStride; OMX_S32 nStride;
OMX_U32 nSliceHeight; OMX_U32 nSliceHeight;
OMX_U32 nBitrate; OMX_U32 nBitrate;
OMX_U32 xFramerate; OMX_U32 xFramerate;
OMX_BOOL bFlagErrorConcealment; OMX_BOOL bFlagErrorConcealment;
OMX_VIDEO_CODINGTYPE eCompressionFormat; OMX_VIDEO_CODINGTYPE eCompressionFormat;
OMX_COLOR_FORMATTYPE eColorFormat; OMX_COLOR_FORMATTYPE eColorFormat;
OMX_NATIVE_WINDOWTYPE pNativeWindow; OMX_NATIVE_WINDOWTYPE pNativeWindow;
} OMX_VIDEO_PORTDEFINITIONTYPE; } OMX_VIDEO_PORTDEFINITIONTYPE;
/** /**
* Port format parameter. This structure is used to enumerate the various * Port format parameter. This structure is used to enumerate the various
* data input/output format supported by the port. * data input/output format supported by the port.
* *
* STRUCT MEMBERS: * STRUCT MEMBERS:
* nSize : Size of the structure in bytes * nSize : Size of the structure in bytes
* nVersion : OMX specification version information * nVersion : OMX specification version information
* nPortIndex : Indicates which port to set * nPortIndex : Indicates which port to set
* nIndex : Indicates the enumeration index for the format from * nIndex : Indicates the enumeration index for the format from
* 0x0 to N-1 * 0x0 to N-1
* eCompressionFormat : Compression format used in this instance of the * eCompressionFormat : Compression format used in this instance of the
* component. When OMX_VIDEO_CodingUnused is specified, * component. When OMX_VIDEO_CodingUnused is specified,
* eColorFormat is used * eColorFormat is used
* eColorFormat : Decompressed format used by this component * eColorFormat : Decompressed format used by this component
* xFrameRate : Indicates the video frame rate in Q16 format * xFrameRate : Indicates the video frame rate in Q16 format
*/ */
typedef struct OMX_VIDEO_PARAM_PORTFORMATTYPE { typedef struct OMX_VIDEO_PARAM_PORTFORMATTYPE {
OMX_U32 nSize; OMX_U32 nSize;
OMX_VERSIONTYPE nVersion; OMX_VERSIONTYPE nVersion;
OMX_U32 nPortIndex; OMX_U32 nPortIndex;
OMX_U32 nIndex; OMX_U32 nIndex;
OMX_VIDEO_CODINGTYPE eCompressionFormat; OMX_VIDEO_CODINGTYPE eCompressionFormat;
OMX_COLOR_FORMATTYPE eColorFormat; OMX_COLOR_FORMATTYPE eColorFormat;
OMX_U32 xFramerate; OMX_U32 xFramerate;
} OMX_VIDEO_PARAM_PORTFORMATTYPE; } OMX_VIDEO_PARAM_PORTFORMATTYPE;
/** /**
* This is a structure for configuring video compression quantization * This is a structure for configuring video compression quantization
* parameter values. Codecs may support different QP values for different * parameter values. Codecs may support different QP values for different
* frame types. * frame types.
* *
* STRUCT MEMBERS: * STRUCT MEMBERS:
* nSize : Size of the structure in bytes * nSize : Size of the structure in bytes
* nVersion : OMX specification version info * nVersion : OMX specification version info
* nPortIndex : Port that this structure applies to * nPortIndex : Port that this structure applies to
* nQpI : QP value to use for index frames * nQpI : QP value to use for index frames
* nQpP : QP value to use for P frames * nQpP : QP value to use for P frames
* nQpB : QP values to use for bidirectional frames * nQpB : QP values to use for bidirectional frames
*/ */
typedef struct OMX_VIDEO_PARAM_QUANTIZATIONTYPE { typedef struct OMX_VIDEO_PARAM_QUANTIZATIONTYPE {
OMX_U32 nSize; OMX_U32 nSize;
OMX_VERSIONTYPE nVersion; OMX_VERSIONTYPE nVersion;
OMX_U32 nPortIndex; OMX_U32 nPortIndex;
OMX_U32 nQpI; OMX_U32 nQpI;
OMX_U32 nQpP; OMX_U32 nQpP;
OMX_U32 nQpB; OMX_U32 nQpB;
} OMX_VIDEO_PARAM_QUANTIZATIONTYPE; } OMX_VIDEO_PARAM_QUANTIZATIONTYPE;
/** /**
* Structure for configuration of video fast update parameters. * Structure for configuration of video fast update parameters.
* *
* STRUCT MEMBERS: * STRUCT MEMBERS:
* nSize : Size of the structure in bytes * nSize : Size of the structure in bytes
* nVersion : OMX specification version info * nVersion : OMX specification version info
* nPortIndex : Port that this structure applies to * nPortIndex : Port that this structure applies to
* bEnableVFU : Enable/Disable video fast update * bEnableVFU : Enable/Disable video fast update
* nFirstGOB : Specifies the number of the first macroblock row * nFirstGOB : Specifies the number of the first macroblock row
* nFirstMB : specifies the first MB relative to the specified first GOB * nFirstMB : specifies the first MB relative to the specified first GOB
* nNumMBs : Specifies the number of MBs to be refreshed from nFirstGOB * nNumMBs : Specifies the number of MBs to be refreshed from nFirstGOB
* and nFirstMB * and nFirstMB
*/ */
typedef struct OMX_VIDEO_PARAM_VIDEOFASTUPDATETYPE { typedef struct OMX_VIDEO_PARAM_VIDEOFASTUPDATETYPE {
OMX_U32 nSize; OMX_U32 nSize;
OMX_VERSIONTYPE nVersion; OMX_VERSIONTYPE nVersion;
OMX_U32 nPortIndex; OMX_U32 nPortIndex;
OMX_BOOL bEnableVFU; OMX_BOOL bEnableVFU;
OMX_U32 nFirstGOB; OMX_U32 nFirstGOB;
OMX_U32 nFirstMB; OMX_U32 nFirstMB;
OMX_U32 nNumMBs; OMX_U32 nNumMBs;
} OMX_VIDEO_PARAM_VIDEOFASTUPDATETYPE; } OMX_VIDEO_PARAM_VIDEOFASTUPDATETYPE;
/** /**
* Enumeration of possible bitrate control types * Enumeration of possible bitrate control types
*/ */
typedef enum OMX_VIDEO_CONTROLRATETYPE { typedef enum OMX_VIDEO_CONTROLRATETYPE {
OMX_Video_ControlRateDisable, OMX_Video_ControlRateDisable,
OMX_Video_ControlRateVariable, OMX_Video_ControlRateVariable,
OMX_Video_ControlRateConstant, OMX_Video_ControlRateConstant,
OMX_Video_ControlRateVariableSkipFrames, OMX_Video_ControlRateVariableSkipFrames,
OMX_Video_ControlRateConstantSkipFrames, OMX_Video_ControlRateConstantSkipFrames,
OMX_Video_ControlRateKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */ OMX_Video_ControlRateKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */
OMX_Video_ControlRateVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */ OMX_Video_ControlRateVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */
OMX_Video_ControlRateMax = 0x7FFFFFFF OMX_Video_ControlRateMax = 0x7FFFFFFF
} OMX_VIDEO_CONTROLRATETYPE; } OMX_VIDEO_CONTROLRATETYPE;
/** /**
* Structure for configuring bitrate mode of a codec. * Structure for configuring bitrate mode of a codec.
* *
* STRUCT MEMBERS: * STRUCT MEMBERS:
* nSize : Size of the struct in bytes * nSize : Size of the struct in bytes
* nVersion : OMX spec version info * nVersion : OMX spec version info
* nPortIndex : Port that this struct applies to * nPortIndex : Port that this struct applies to
* eControlRate : Control rate type enum * eControlRate : Control rate type enum
* nTargetBitrate : Target bitrate to encode with * nTargetBitrate : Target bitrate to encode with
*/ */
typedef struct OMX_VIDEO_PARAM_BITRATETYPE { typedef struct OMX_VIDEO_PARAM_BITRATETYPE {
OMX_U32 nSize; OMX_U32 nSize;
OMX_VERSIONTYPE nVersion; OMX_VERSIONTYPE nVersion;
OMX_U32 nPortIndex; OMX_U32 nPortIndex;
OMX_VIDEO_CONTROLRATETYPE eControlRate; OMX_VIDEO_CONTROLRATETYPE eControlRate;
OMX_U32 nTargetBitrate; OMX_U32 nTargetBitrate;
} OMX_VIDEO_PARAM_BITRATETYPE; } OMX_VIDEO_PARAM_BITRATETYPE;
/** /**
* Enumeration of possible motion vector (MV) types * Enumeration of possible motion vector (MV) types
*/ */
typedef enum OMX_VIDEO_MOTIONVECTORTYPE { typedef enum OMX_VIDEO_MOTIONVECTORTYPE {
OMX_Video_MotionVectorPixel, OMX_Video_MotionVectorPixel,
OMX_Video_MotionVectorHalfPel, OMX_Video_MotionVectorHalfPel,
OMX_Video_MotionVectorQuarterPel, OMX_Video_MotionVectorQuarterPel,
OMX_Video_MotionVectorEighthPel, OMX_Video_MotionVectorEighthPel,
OMX_Video_MotionVectorKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */ OMX_Video_MotionVectorKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */
OMX_Video_MotionVectorVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */ OMX_Video_MotionVectorVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */
OMX_Video_MotionVectorMax = 0x7FFFFFFF OMX_Video_MotionVectorMax = 0x7FFFFFFF
} OMX_VIDEO_MOTIONVECTORTYPE; } OMX_VIDEO_MOTIONVECTORTYPE;
/** /**
* Structure for configuring the number of motion vectors used as well * Structure for configuring the number of motion vectors used as well
* as their accuracy. * as their accuracy.
* *
* STRUCT MEMBERS: * STRUCT MEMBERS:
* nSize : Size of the struct in bytes * nSize : Size of the struct in bytes
* nVersion : OMX spec version info * nVersion : OMX spec version info
* nPortIndex : port that this structure applies to * nPortIndex : port that this structure applies to
* eAccuracy : Enumerated MV accuracy * eAccuracy : Enumerated MV accuracy
* bUnrestrictedMVs : Allow unrestricted MVs * bUnrestrictedMVs : Allow unrestricted MVs
* bFourMV : Allow use of 4 MVs * bFourMV : Allow use of 4 MVs
* sXSearchRange : Search range in horizontal direction for MVs * sXSearchRange : Search range in horizontal direction for MVs
* sYSearchRange : Search range in vertical direction for MVs * sYSearchRange : Search range in vertical direction for MVs
*/ */
typedef struct OMX_VIDEO_PARAM_MOTIONVECTORTYPE { typedef struct OMX_VIDEO_PARAM_MOTIONVECTORTYPE {
OMX_U32 nSize; OMX_U32 nSize;
OMX_VERSIONTYPE nVersion; OMX_VERSIONTYPE nVersion;
OMX_U32 nPortIndex; OMX_U32 nPortIndex;
OMX_VIDEO_MOTIONVECTORTYPE eAccuracy; OMX_VIDEO_MOTIONVECTORTYPE eAccuracy;
OMX_BOOL bUnrestrictedMVs; OMX_BOOL bUnrestrictedMVs;
OMX_BOOL bFourMV; OMX_BOOL bFourMV;
OMX_S32 sXSearchRange; OMX_S32 sXSearchRange;
OMX_S32 sYSearchRange; OMX_S32 sYSearchRange;
} OMX_VIDEO_PARAM_MOTIONVECTORTYPE; } OMX_VIDEO_PARAM_MOTIONVECTORTYPE;
/** /**
* Enumeration of possible methods to use for Intra Refresh * Enumeration of possible methods to use for Intra Refresh
*/ */
typedef enum OMX_VIDEO_INTRAREFRESHTYPE { typedef enum OMX_VIDEO_INTRAREFRESHTYPE {
OMX_VIDEO_IntraRefreshCyclic, OMX_VIDEO_IntraRefreshCyclic,
OMX_VIDEO_IntraRefreshAdaptive, OMX_VIDEO_IntraRefreshAdaptive,
OMX_VIDEO_IntraRefreshBoth, OMX_VIDEO_IntraRefreshBoth,
OMX_VIDEO_IntraRefreshKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */ OMX_VIDEO_IntraRefreshKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */
OMX_VIDEO_IntraRefreshVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */ OMX_VIDEO_IntraRefreshVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */
OMX_VIDEO_IntraRefreshMax = 0x7FFFFFFF OMX_VIDEO_IntraRefreshMax = 0x7FFFFFFF
} OMX_VIDEO_INTRAREFRESHTYPE; } OMX_VIDEO_INTRAREFRESHTYPE;
/** /**
* Structure for configuring intra refresh mode * Structure for configuring intra refresh mode
* *
* STRUCT MEMBERS: * STRUCT MEMBERS:
* nSize : Size of the structure in bytes * nSize : Size of the structure in bytes
* nVersion : OMX specification version information * nVersion : OMX specification version information
* nPortIndex : Port that this structure applies to * nPortIndex : Port that this structure applies to
* eRefreshMode : Cyclic, Adaptive, or Both * eRefreshMode : Cyclic, Adaptive, or Both
* nAirMBs : Number of intra macroblocks to refresh in a frame when * nAirMBs : Number of intra macroblocks to refresh in a frame when
* AIR is enabled * AIR is enabled
* nAirRef : Number of times a motion marked macroblock has to be * nAirRef : Number of times a motion marked macroblock has to be
* intra coded * intra coded
* nCirMBs : Number of consecutive macroblocks to be coded as "intra" * nCirMBs : Number of consecutive macroblocks to be coded as "intra"
* when CIR is enabled * when CIR is enabled
*/ */
typedef struct OMX_VIDEO_PARAM_INTRAREFRESHTYPE { typedef struct OMX_VIDEO_PARAM_INTRAREFRESHTYPE {
OMX_U32 nSize; OMX_U32 nSize;
OMX_VERSIONTYPE nVersion; OMX_VERSIONTYPE nVersion;
OMX_U32 nPortIndex; OMX_U32 nPortIndex;
OMX_VIDEO_INTRAREFRESHTYPE eRefreshMode; OMX_VIDEO_INTRAREFRESHTYPE eRefreshMode;
OMX_U32 nAirMBs; OMX_U32 nAirMBs;
OMX_U32 nAirRef; OMX_U32 nAirRef;
OMX_U32 nCirMBs; OMX_U32 nCirMBs;
} OMX_VIDEO_PARAM_INTRAREFRESHTYPE; } OMX_VIDEO_PARAM_INTRAREFRESHTYPE;
/** /**
* Structure for enabling various error correction methods for video * Structure for enabling various error correction methods for video
* compression. * compression.
* *
* STRUCT MEMBERS: * STRUCT MEMBERS:
* nSize : Size of the structure in bytes * nSize : Size of the structure in bytes
* nVersion : OMX specification version information * nVersion : OMX specification version information
* nPortIndex : Port that this structure applies to * nPortIndex : Port that this structure applies to
* bEnableHEC : Enable/disable header extension codes (HEC) * bEnableHEC : Enable/disable header extension codes (HEC)
* bEnableResync : Enable/disable resynchronization markers * bEnableResync : Enable/disable resynchronization markers
* nResynchMarkerSpacing : Resynch markers interval (in bits) to be * nResynchMarkerSpacing : Resynch markers interval (in bits) to be
* applied in the stream * applied in the stream
* bEnableDataPartitioning : Enable/disable data partitioning * bEnableDataPartitioning : Enable/disable data partitioning
* bEnableRVLC : Enable/disable reversible variable length * bEnableRVLC : Enable/disable reversible variable length
* coding * coding
*/ */
typedef struct OMX_VIDEO_PARAM_ERRORCORRECTIONTYPE { typedef struct OMX_VIDEO_PARAM_ERRORCORRECTIONTYPE {
OMX_U32 nSize; OMX_U32 nSize;
OMX_VERSIONTYPE nVersion; OMX_VERSIONTYPE nVersion;
OMX_U32 nPortIndex; OMX_U32 nPortIndex;
OMX_BOOL bEnableHEC; OMX_BOOL bEnableHEC;
OMX_BOOL bEnableResync; OMX_BOOL bEnableResync;
OMX_U32 nResynchMarkerSpacing; OMX_U32 nResynchMarkerSpacing;
OMX_BOOL bEnableDataPartitioning; OMX_BOOL bEnableDataPartitioning;
OMX_BOOL bEnableRVLC; OMX_BOOL bEnableRVLC;
} OMX_VIDEO_PARAM_ERRORCORRECTIONTYPE; } OMX_VIDEO_PARAM_ERRORCORRECTIONTYPE;
/** /**
* Configuration of variable block-size motion compensation (VBSMC) * Configuration of variable block-size motion compensation (VBSMC)
* *
* STRUCT MEMBERS: * STRUCT MEMBERS:
* nSize : Size of the structure in bytes * nSize : Size of the structure in bytes
* nVersion : OMX specification version information * nVersion : OMX specification version information
* nPortIndex : Port that this structure applies to * nPortIndex : Port that this structure applies to
* b16x16 : Enable inter block search 16x16 * b16x16 : Enable inter block search 16x16
* b16x8 : Enable inter block search 16x8 * b16x8 : Enable inter block search 16x8
* b8x16 : Enable inter block search 8x16 * b8x16 : Enable inter block search 8x16
* b8x8 : Enable inter block search 8x8 * b8x8 : Enable inter block search 8x8
* b8x4 : Enable inter block search 8x4 * b8x4 : Enable inter block search 8x4
* b4x8 : Enable inter block search 4x8 * b4x8 : Enable inter block search 4x8
* b4x4 : Enable inter block search 4x4 * b4x4 : Enable inter block search 4x4
*/ */
typedef struct OMX_VIDEO_PARAM_VBSMCTYPE { typedef struct OMX_VIDEO_PARAM_VBSMCTYPE {
OMX_U32 nSize; OMX_U32 nSize;
OMX_VERSIONTYPE nVersion; OMX_VERSIONTYPE nVersion;
OMX_U32 nPortIndex; OMX_U32 nPortIndex;
OMX_BOOL b16x16; OMX_BOOL b16x16;
OMX_BOOL b16x8; OMX_BOOL b16x8;
OMX_BOOL b8x16; OMX_BOOL b8x16;
OMX_BOOL b8x8; OMX_BOOL b8x8;
OMX_BOOL b8x4; OMX_BOOL b8x4;
OMX_BOOL b4x8; OMX_BOOL b4x8;
OMX_BOOL b4x4; OMX_BOOL b4x4;
} OMX_VIDEO_PARAM_VBSMCTYPE; } OMX_VIDEO_PARAM_VBSMCTYPE;
/** /**
* H.263 profile types, each profile indicates support for various * H.263 profile types, each profile indicates support for various
* performance bounds and different annexes. * performance bounds and different annexes.
* *
* ENUMS: * ENUMS:
* Baseline : Baseline Profile: H.263 (V1), no optional modes * Baseline : Baseline Profile: H.263 (V1), no optional modes
* H320 Coding : H.320 Coding Efficiency Backward Compatibility * H320 Coding : H.320 Coding Efficiency Backward Compatibility
* Profile: H.263+ (V2), includes annexes I, J, L.4 * Profile: H.263+ (V2), includes annexes I, J, L.4
* and T * and T
* BackwardCompatible : Backward Compatibility Profile: H.263 (V1), * BackwardCompatible : Backward Compatibility Profile: H.263 (V1),
* includes annex F * includes annex F
* ISWV2 : Interactive Streaming Wireless Profile: H.263+ * ISWV2 : Interactive Streaming Wireless Profile: H.263+
* (V2), includes annexes I, J, K and T * (V2), includes annexes I, J, K and T
* ISWV3 : Interactive Streaming Wireless Profile: H.263++ * ISWV3 : Interactive Streaming Wireless Profile: H.263++
* (V3), includes profile 3 and annexes V and W.6.3.8 * (V3), includes profile 3 and annexes V and W.6.3.8
* HighCompression : Conversational High Compression Profile: H.263++ * HighCompression : Conversational High Compression Profile: H.263++
* (V3), includes profiles 1 & 2 and annexes D and U * (V3), includes profiles 1 & 2 and annexes D and U
* Internet : Conversational Internet Profile: H.263++ (V3), * Internet : Conversational Internet Profile: H.263++ (V3),
* includes profile 5 and annex K * includes profile 5 and annex K
* Interlace : Conversational Interlace Profile: H.263++ (V3), * Interlace : Conversational Interlace Profile: H.263++ (V3),
* includes profile 5 and annex W.6.3.11 * includes profile 5 and annex W.6.3.11
* HighLatency : High Latency Profile: H.263++ (V3), includes * HighLatency : High Latency Profile: H.263++ (V3), includes
* profile 6 and annexes O.1 and P.5 * profile 6 and annexes O.1 and P.5
*/ */
typedef enum OMX_VIDEO_H263PROFILETYPE { typedef enum OMX_VIDEO_H263PROFILETYPE {
OMX_VIDEO_H263ProfileBaseline = 0x01, OMX_VIDEO_H263ProfileBaseline = 0x01,
OMX_VIDEO_H263ProfileH320Coding = 0x02, OMX_VIDEO_H263ProfileH320Coding = 0x02,
OMX_VIDEO_H263ProfileBackwardCompatible = 0x04, OMX_VIDEO_H263ProfileBackwardCompatible = 0x04,
OMX_VIDEO_H263ProfileISWV2 = 0x08, OMX_VIDEO_H263ProfileISWV2 = 0x08,
OMX_VIDEO_H263ProfileISWV3 = 0x10, OMX_VIDEO_H263ProfileISWV3 = 0x10,
OMX_VIDEO_H263ProfileHighCompression = 0x20, OMX_VIDEO_H263ProfileHighCompression = 0x20,
OMX_VIDEO_H263ProfileInternet = 0x40, OMX_VIDEO_H263ProfileInternet = 0x40,
OMX_VIDEO_H263ProfileInterlace = 0x80, OMX_VIDEO_H263ProfileInterlace = 0x80,
OMX_VIDEO_H263ProfileHighLatency = 0x100, OMX_VIDEO_H263ProfileHighLatency = 0x100,
OMX_VIDEO_H263ProfileKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */ OMX_VIDEO_H263ProfileKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */
OMX_VIDEO_H263ProfileVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */ OMX_VIDEO_H263ProfileVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */
OMX_VIDEO_H263ProfileMax = 0x7FFFFFFF OMX_VIDEO_H263ProfileMax = 0x7FFFFFFF
} OMX_VIDEO_H263PROFILETYPE; } OMX_VIDEO_H263PROFILETYPE;
/** /**
* H.263 level types, each level indicates support for various frame sizes, * H.263 level types, each level indicates support for various frame sizes,
* bit rates, decoder frame rates. * bit rates, decoder frame rates.
*/ */
typedef enum OMX_VIDEO_H263LEVELTYPE { typedef enum OMX_VIDEO_H263LEVELTYPE {
OMX_VIDEO_H263Level10 = 0x01, OMX_VIDEO_H263Level10 = 0x01,
OMX_VIDEO_H263Level20 = 0x02, OMX_VIDEO_H263Level20 = 0x02,
OMX_VIDEO_H263Level30 = 0x04, OMX_VIDEO_H263Level30 = 0x04,
OMX_VIDEO_H263Level40 = 0x08, OMX_VIDEO_H263Level40 = 0x08,
OMX_VIDEO_H263Level45 = 0x10, OMX_VIDEO_H263Level45 = 0x10,
OMX_VIDEO_H263Level50 = 0x20, OMX_VIDEO_H263Level50 = 0x20,
OMX_VIDEO_H263Level60 = 0x40, OMX_VIDEO_H263Level60 = 0x40,
OMX_VIDEO_H263Level70 = 0x80, OMX_VIDEO_H263Level70 = 0x80,
OMX_VIDEO_H263LevelKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */ OMX_VIDEO_H263LevelKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */
OMX_VIDEO_H263LevelVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */ OMX_VIDEO_H263LevelVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */
OMX_VIDEO_H263LevelMax = 0x7FFFFFFF OMX_VIDEO_H263LevelMax = 0x7FFFFFFF
} OMX_VIDEO_H263LEVELTYPE; } OMX_VIDEO_H263LEVELTYPE;
/** /**
* Specifies the picture type. These values should be OR'd to signal all * Specifies the picture type. These values should be OR'd to signal all
* pictures types which are allowed. * pictures types which are allowed.
* *
* ENUMS: * ENUMS:
* Generic Picture Types: I, P and B * Generic Picture Types: I, P and B
* H.263 Specific Picture Types: SI and SP * H.263 Specific Picture Types: SI and SP
* H.264 Specific Picture Types: EI and EP * H.264 Specific Picture Types: EI and EP
* MPEG-4 Specific Picture Types: S * MPEG-4 Specific Picture Types: S
*/ */
typedef enum OMX_VIDEO_PICTURETYPE { typedef enum OMX_VIDEO_PICTURETYPE {
OMX_VIDEO_PictureTypeI = 0x01, OMX_VIDEO_PictureTypeI = 0x01,
OMX_VIDEO_PictureTypeP = 0x02, OMX_VIDEO_PictureTypeP = 0x02,
OMX_VIDEO_PictureTypeB = 0x04, OMX_VIDEO_PictureTypeB = 0x04,
OMX_VIDEO_PictureTypeSI = 0x08, OMX_VIDEO_PictureTypeSI = 0x08,
OMX_VIDEO_PictureTypeSP = 0x10, OMX_VIDEO_PictureTypeSP = 0x10,
OMX_VIDEO_PictureTypeEI = 0x11, OMX_VIDEO_PictureTypeEI = 0x11,
OMX_VIDEO_PictureTypeEP = 0x12, OMX_VIDEO_PictureTypeEP = 0x12,
OMX_VIDEO_PictureTypeS = 0x14, OMX_VIDEO_PictureTypeS = 0x14,
OMX_VIDEO_PictureTypeKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */ OMX_VIDEO_PictureTypeKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */
OMX_VIDEO_PictureTypeVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */ OMX_VIDEO_PictureTypeVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */
OMX_VIDEO_PictureTypeMax = 0x7FFFFFFF OMX_VIDEO_PictureTypeMax = 0x7FFFFFFF
} OMX_VIDEO_PICTURETYPE; } OMX_VIDEO_PICTURETYPE;
/** /**
* H.263 Params * H.263 Params
* *
* STRUCT MEMBERS: * STRUCT MEMBERS:
* nSize : Size of the structure in bytes * nSize : Size of the structure in bytes
* nVersion : OMX specification version information * nVersion : OMX specification version information
* nPortIndex : Port that this structure applies to * nPortIndex : Port that this structure applies to
* nPFrames : Number of P frames between each I frame * nPFrames : Number of P frames between each I frame
* nBFrames : Number of B frames between each I frame * nBFrames : Number of B frames between each I frame
* eProfile : H.263 profile(s) to use * eProfile : H.263 profile(s) to use
* eLevel : H.263 level(s) to use * eLevel : H.263 level(s) to use
* bPLUSPTYPEAllowed : Indicating that it is allowed to use PLUSPTYPE * bPLUSPTYPEAllowed : Indicating that it is allowed to use PLUSPTYPE
* (specified in the 1998 version of H.263) to * (specified in the 1998 version of H.263) to
* indicate custom picture sizes or clock * indicate custom picture sizes or clock
* frequencies * frequencies
* nAllowedPictureTypes : Specifies the picture types allowed in the * nAllowedPictureTypes : Specifies the picture types allowed in the
* bitstream * bitstream
* bForceRoundingTypeToZero : value of the RTYPE bit (bit 6 of MPPTYPE) is * bForceRoundingTypeToZero : value of the RTYPE bit (bit 6 of MPPTYPE) is
* not constrained. It is recommended to change * not constrained. It is recommended to change
* the value of the RTYPE bit for each reference * the value of the RTYPE bit for each reference
* picture in error-free communication * picture in error-free communication
* nPictureHeaderRepetition : Specifies the frequency of picture header * nPictureHeaderRepetition : Specifies the frequency of picture header
* repetition * repetition
* nGOBHeaderInterval : Specifies the interval of non-empty GOB * nGOBHeaderInterval : Specifies the interval of non-empty GOB
* headers in units of GOBs * headers in units of GOBs
*/ */
typedef struct OMX_VIDEO_PARAM_H263TYPE { typedef struct OMX_VIDEO_PARAM_H263TYPE {
OMX_U32 nSize; OMX_U32 nSize;
OMX_VERSIONTYPE nVersion; OMX_VERSIONTYPE nVersion;
OMX_U32 nPortIndex; OMX_U32 nPortIndex;
OMX_U32 nPFrames; OMX_U32 nPFrames;
OMX_U32 nBFrames; OMX_U32 nBFrames;
OMX_VIDEO_H263PROFILETYPE eProfile; OMX_VIDEO_H263PROFILETYPE eProfile;
OMX_VIDEO_H263LEVELTYPE eLevel; OMX_VIDEO_H263LEVELTYPE eLevel;
OMX_BOOL bPLUSPTYPEAllowed; OMX_BOOL bPLUSPTYPEAllowed;
OMX_U32 nAllowedPictureTypes; OMX_U32 nAllowedPictureTypes;
OMX_BOOL bForceRoundingTypeToZero; OMX_BOOL bForceRoundingTypeToZero;
OMX_U32 nPictureHeaderRepetition; OMX_U32 nPictureHeaderRepetition;
OMX_U32 nGOBHeaderInterval; OMX_U32 nGOBHeaderInterval;
} OMX_VIDEO_PARAM_H263TYPE; } OMX_VIDEO_PARAM_H263TYPE;
/** /**
* MPEG-2 profile types, each profile indicates support for various * MPEG-2 profile types, each profile indicates support for various
* performance bounds and different annexes. * performance bounds and different annexes.
*/ */
typedef enum OMX_VIDEO_MPEG2PROFILETYPE { typedef enum OMX_VIDEO_MPEG2PROFILETYPE {
OMX_VIDEO_MPEG2ProfileSimple = 0, /**< Simple Profile */ OMX_VIDEO_MPEG2ProfileSimple = 0, /**< Simple Profile */
OMX_VIDEO_MPEG2ProfileMain, /**< Main Profile */ OMX_VIDEO_MPEG2ProfileMain, /**< Main Profile */
OMX_VIDEO_MPEG2Profile422, /**< 4:2:2 Profile */ OMX_VIDEO_MPEG2Profile422, /**< 4:2:2 Profile */
OMX_VIDEO_MPEG2ProfileSNR, /**< SNR Profile */ OMX_VIDEO_MPEG2ProfileSNR, /**< SNR Profile */
OMX_VIDEO_MPEG2ProfileSpatial, /**< Spatial Profile */ OMX_VIDEO_MPEG2ProfileSpatial, /**< Spatial Profile */
OMX_VIDEO_MPEG2ProfileHigh, /**< High Profile */ OMX_VIDEO_MPEG2ProfileHigh, /**< High Profile */
OMX_VIDEO_MPEG2ProfileKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */ OMX_VIDEO_MPEG2ProfileKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */
OMX_VIDEO_MPEG2ProfileVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */ OMX_VIDEO_MPEG2ProfileVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */
OMX_VIDEO_MPEG2ProfileMax = 0x7FFFFFFF OMX_VIDEO_MPEG2ProfileMax = 0x7FFFFFFF
} OMX_VIDEO_MPEG2PROFILETYPE; } OMX_VIDEO_MPEG2PROFILETYPE;
/** /**
* MPEG-2 level types, each level indicates support for various frame * MPEG-2 level types, each level indicates support for various frame
* sizes, bit rates, decoder frame rates. No need * sizes, bit rates, decoder frame rates. No need
*/ */
typedef enum OMX_VIDEO_MPEG2LEVELTYPE { typedef enum OMX_VIDEO_MPEG2LEVELTYPE {
OMX_VIDEO_MPEG2LevelLL = 0, /**< Low Level */ OMX_VIDEO_MPEG2LevelLL = 0, /**< Low Level */
OMX_VIDEO_MPEG2LevelML, /**< Main Level */ OMX_VIDEO_MPEG2LevelML, /**< Main Level */
OMX_VIDEO_MPEG2LevelH14, /**< High 1440 */ OMX_VIDEO_MPEG2LevelH14, /**< High 1440 */
OMX_VIDEO_MPEG2LevelHL, /**< High Level */ OMX_VIDEO_MPEG2LevelHL, /**< High Level */
OMX_VIDEO_MPEG2LevelKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */ OMX_VIDEO_MPEG2LevelKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */
OMX_VIDEO_MPEG2LevelVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */ OMX_VIDEO_MPEG2LevelVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */
OMX_VIDEO_MPEG2LevelMax = 0x7FFFFFFF OMX_VIDEO_MPEG2LevelMax = 0x7FFFFFFF
} OMX_VIDEO_MPEG2LEVELTYPE; } OMX_VIDEO_MPEG2LEVELTYPE;
/** /**
* MPEG-2 params * MPEG-2 params
* *
* STRUCT MEMBERS: * STRUCT MEMBERS:
* nSize : Size of the structure in bytes * nSize : Size of the structure in bytes
* nVersion : OMX specification version information * nVersion : OMX specification version information
* nPortIndex : Port that this structure applies to * nPortIndex : Port that this structure applies to
* nPFrames : Number of P frames between each I frame * nPFrames : Number of P frames between each I frame
* nBFrames : Number of B frames between each I frame * nBFrames : Number of B frames between each I frame
* eProfile : MPEG-2 profile(s) to use * eProfile : MPEG-2 profile(s) to use
* eLevel : MPEG-2 levels(s) to use * eLevel : MPEG-2 levels(s) to use
*/ */
typedef struct OMX_VIDEO_PARAM_MPEG2TYPE { typedef struct OMX_VIDEO_PARAM_MPEG2TYPE {
OMX_U32 nSize; OMX_U32 nSize;
OMX_VERSIONTYPE nVersion; OMX_VERSIONTYPE nVersion;
OMX_U32 nPortIndex; OMX_U32 nPortIndex;
OMX_U32 nPFrames; OMX_U32 nPFrames;
OMX_U32 nBFrames; OMX_U32 nBFrames;
OMX_VIDEO_MPEG2PROFILETYPE eProfile; OMX_VIDEO_MPEG2PROFILETYPE eProfile;
OMX_VIDEO_MPEG2LEVELTYPE eLevel; OMX_VIDEO_MPEG2LEVELTYPE eLevel;
} OMX_VIDEO_PARAM_MPEG2TYPE; } OMX_VIDEO_PARAM_MPEG2TYPE;
/** /**
* MPEG-4 profile types, each profile indicates support for various * MPEG-4 profile types, each profile indicates support for various
* performance bounds and different annexes. * performance bounds and different annexes.
* *
* ENUMS: * ENUMS:
* - Simple Profile, Levels 1-3 * - Simple Profile, Levels 1-3
* - Simple Scalable Profile, Levels 1-2 * - Simple Scalable Profile, Levels 1-2
* - Core Profile, Levels 1-2 * - Core Profile, Levels 1-2
* - Main Profile, Levels 2-4 * - Main Profile, Levels 2-4
* - N-bit Profile, Level 2 * - N-bit Profile, Level 2
* - Scalable Texture Profile, Level 1 * - Scalable Texture Profile, Level 1
* - Simple Face Animation Profile, Levels 1-2 * - Simple Face Animation Profile, Levels 1-2
* - Simple Face and Body Animation (FBA) Profile, Levels 1-2 * - Simple Face and Body Animation (FBA) Profile, Levels 1-2
* - Basic Animated Texture Profile, Levels 1-2 * - Basic Animated Texture Profile, Levels 1-2
* - Hybrid Profile, Levels 1-2 * - Hybrid Profile, Levels 1-2
* - Advanced Real Time Simple Profiles, Levels 1-4 * - Advanced Real Time Simple Profiles, Levels 1-4
* - Core Scalable Profile, Levels 1-3 * - Core Scalable Profile, Levels 1-3
* - Advanced Coding Efficiency Profile, Levels 1-4 * - Advanced Coding Efficiency Profile, Levels 1-4
* - Advanced Core Profile, Levels 1-2 * - Advanced Core Profile, Levels 1-2
* - Advanced Scalable Texture, Levels 2-3 * - Advanced Scalable Texture, Levels 2-3
*/ */
typedef enum OMX_VIDEO_MPEG4PROFILETYPE { typedef enum OMX_VIDEO_MPEG4PROFILETYPE {
OMX_VIDEO_MPEG4ProfileSimple = 0x01, OMX_VIDEO_MPEG4ProfileSimple = 0x01,
OMX_VIDEO_MPEG4ProfileSimpleScalable = 0x02, OMX_VIDEO_MPEG4ProfileSimpleScalable = 0x02,
OMX_VIDEO_MPEG4ProfileCore = 0x04, OMX_VIDEO_MPEG4ProfileCore = 0x04,
OMX_VIDEO_MPEG4ProfileMain = 0x08, OMX_VIDEO_MPEG4ProfileMain = 0x08,
OMX_VIDEO_MPEG4ProfileNbit = 0x10, OMX_VIDEO_MPEG4ProfileNbit = 0x10,
OMX_VIDEO_MPEG4ProfileScalableTexture = 0x20, OMX_VIDEO_MPEG4ProfileScalableTexture = 0x20,
OMX_VIDEO_MPEG4ProfileSimpleFace = 0x40, OMX_VIDEO_MPEG4ProfileSimpleFace = 0x40,
OMX_VIDEO_MPEG4ProfileSimpleFBA = 0x80, OMX_VIDEO_MPEG4ProfileSimpleFBA = 0x80,
OMX_VIDEO_MPEG4ProfileBasicAnimated = 0x100, OMX_VIDEO_MPEG4ProfileBasicAnimated = 0x100,
OMX_VIDEO_MPEG4ProfileHybrid = 0x200, OMX_VIDEO_MPEG4ProfileHybrid = 0x200,
OMX_VIDEO_MPEG4ProfileAdvancedRealTime = 0x400, OMX_VIDEO_MPEG4ProfileAdvancedRealTime = 0x400,
OMX_VIDEO_MPEG4ProfileCoreScalable = 0x800, OMX_VIDEO_MPEG4ProfileCoreScalable = 0x800,
OMX_VIDEO_MPEG4ProfileAdvancedCoding = 0x1000, OMX_VIDEO_MPEG4ProfileAdvancedCoding = 0x1000,
OMX_VIDEO_MPEG4ProfileAdvancedCore = 0x2000, OMX_VIDEO_MPEG4ProfileAdvancedCore = 0x2000,
OMX_VIDEO_MPEG4ProfileAdvancedScalable = 0x4000, OMX_VIDEO_MPEG4ProfileAdvancedScalable = 0x4000,
OMX_VIDEO_MPEG4ProfileAdvancedSimple = 0x8000, OMX_VIDEO_MPEG4ProfileAdvancedSimple = 0x8000,
OMX_VIDEO_MPEG4ProfileKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */ OMX_VIDEO_MPEG4ProfileKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */
OMX_VIDEO_MPEG4ProfileVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */ OMX_VIDEO_MPEG4ProfileVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */
OMX_VIDEO_MPEG4ProfileMax = 0x7FFFFFFF OMX_VIDEO_MPEG4ProfileMax = 0x7FFFFFFF
} OMX_VIDEO_MPEG4PROFILETYPE; } OMX_VIDEO_MPEG4PROFILETYPE;
/** /**
* MPEG-4 level types, each level indicates support for various frame * MPEG-4 level types, each level indicates support for various frame
* sizes, bit rates, decoder frame rates. No need * sizes, bit rates, decoder frame rates. No need
*/ */
typedef enum OMX_VIDEO_MPEG4LEVELTYPE { typedef enum OMX_VIDEO_MPEG4LEVELTYPE {
OMX_VIDEO_MPEG4Level0 = 0x01, /**< Level 0 */ OMX_VIDEO_MPEG4Level0 = 0x01, /**< Level 0 */
OMX_VIDEO_MPEG4Level0b = 0x02, /**< Level 0b */ OMX_VIDEO_MPEG4Level0b = 0x02, /**< Level 0b */
OMX_VIDEO_MPEG4Level1 = 0x04, /**< Level 1 */ OMX_VIDEO_MPEG4Level1 = 0x04, /**< Level 1 */
OMX_VIDEO_MPEG4Level2 = 0x08, /**< Level 2 */ OMX_VIDEO_MPEG4Level2 = 0x08, /**< Level 2 */
OMX_VIDEO_MPEG4Level3 = 0x10, /**< Level 3 */ OMX_VIDEO_MPEG4Level3 = 0x10, /**< Level 3 */
OMX_VIDEO_MPEG4Level4 = 0x20, /**< Level 4 */ OMX_VIDEO_MPEG4Level4 = 0x20, /**< Level 4 */
OMX_VIDEO_MPEG4Level4a = 0x40, /**< Level 4a */ OMX_VIDEO_MPEG4Level4a = 0x40, /**< Level 4a */
OMX_VIDEO_MPEG4Level5 = 0x80, /**< Level 5 */ OMX_VIDEO_MPEG4Level5 = 0x80, /**< Level 5 */
OMX_VIDEO_MPEG4LevelKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */ OMX_VIDEO_MPEG4LevelKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */
OMX_VIDEO_MPEG4LevelVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */ OMX_VIDEO_MPEG4LevelVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */
OMX_VIDEO_MPEG4LevelMax = 0x7FFFFFFF OMX_VIDEO_MPEG4LevelMax = 0x7FFFFFFF
} OMX_VIDEO_MPEG4LEVELTYPE; } OMX_VIDEO_MPEG4LEVELTYPE;
/** /**
* MPEG-4 configuration. This structure handles configuration options * MPEG-4 configuration. This structure handles configuration options
* which are specific to MPEG4 algorithms * which are specific to MPEG4 algorithms
* *
* STRUCT MEMBERS: * STRUCT MEMBERS:
* nSize : Size of the structure in bytes * nSize : Size of the structure in bytes
* nVersion : OMX specification version information * nVersion : OMX specification version information
* nPortIndex : Port that this structure applies to * nPortIndex : Port that this structure applies to
* nSliceHeaderSpacing : Number of macroblocks between slice header (H263+ * nSliceHeaderSpacing : Number of macroblocks between slice header (H263+
* Annex K). Put zero if not used * Annex K). Put zero if not used
* bSVH : Enable Short Video Header mode * bSVH : Enable Short Video Header mode
* bGov : Flag to enable GOV * bGov : Flag to enable GOV
* nPFrames : Number of P frames between each I frame (also called * nPFrames : Number of P frames between each I frame (also called
* GOV period) * GOV period)
* nBFrames : Number of B frames between each I frame * nBFrames : Number of B frames between each I frame
* nIDCVLCThreshold : Value of intra DC VLC threshold * nIDCVLCThreshold : Value of intra DC VLC threshold
* bACPred : Flag to use ac prediction * bACPred : Flag to use ac prediction
* nMaxPacketSize : Maximum size of packet in bytes. * nMaxPacketSize : Maximum size of packet in bytes.
* nTimeIncRes : Used to pass VOP time increment resolution for MPEG4. * nTimeIncRes : Used to pass VOP time increment resolution for MPEG4.
* Interpreted as described in MPEG4 standard. * Interpreted as described in MPEG4 standard.
* eProfile : MPEG-4 profile(s) to use. * eProfile : MPEG-4 profile(s) to use.
* eLevel : MPEG-4 level(s) to use. * eLevel : MPEG-4 level(s) to use.
* nAllowedPictureTypes : Specifies the picture types allowed in the bitstream * nAllowedPictureTypes : Specifies the picture types allowed in the bitstream
* nHeaderExtension : Specifies the number of consecutive video packet * nHeaderExtension : Specifies the number of consecutive video packet
* headers within a VOP * headers within a VOP
* bReversibleVLC : Specifies whether reversible variable length coding * bReversibleVLC : Specifies whether reversible variable length coding
* is in use * is in use
*/ */
typedef struct OMX_VIDEO_PARAM_MPEG4TYPE { typedef struct OMX_VIDEO_PARAM_MPEG4TYPE {
OMX_U32 nSize; OMX_U32 nSize;
OMX_VERSIONTYPE nVersion; OMX_VERSIONTYPE nVersion;
OMX_U32 nPortIndex; OMX_U32 nPortIndex;
OMX_U32 nSliceHeaderSpacing; OMX_U32 nSliceHeaderSpacing;
OMX_BOOL bSVH; OMX_BOOL bSVH;
OMX_BOOL bGov; OMX_BOOL bGov;
OMX_U32 nPFrames; OMX_U32 nPFrames;
OMX_U32 nBFrames; OMX_U32 nBFrames;
OMX_U32 nIDCVLCThreshold; OMX_U32 nIDCVLCThreshold;
OMX_BOOL bACPred; OMX_BOOL bACPred;
OMX_U32 nMaxPacketSize; OMX_U32 nMaxPacketSize;
OMX_U32 nTimeIncRes; OMX_U32 nTimeIncRes;
OMX_VIDEO_MPEG4PROFILETYPE eProfile; OMX_VIDEO_MPEG4PROFILETYPE eProfile;
OMX_VIDEO_MPEG4LEVELTYPE eLevel; OMX_VIDEO_MPEG4LEVELTYPE eLevel;
OMX_U32 nAllowedPictureTypes; OMX_U32 nAllowedPictureTypes;
OMX_U32 nHeaderExtension; OMX_U32 nHeaderExtension;
OMX_BOOL bReversibleVLC; OMX_BOOL bReversibleVLC;
} OMX_VIDEO_PARAM_MPEG4TYPE; } OMX_VIDEO_PARAM_MPEG4TYPE;
/** /**
* WMV Versions * WMV Versions
*/ */
typedef enum OMX_VIDEO_WMVFORMATTYPE { typedef enum OMX_VIDEO_WMVFORMATTYPE {
OMX_VIDEO_WMVFormatUnused = 0x01, /**< Format unused or unknown */ OMX_VIDEO_WMVFormatUnused = 0x01, /**< Format unused or unknown */
OMX_VIDEO_WMVFormat7 = 0x02, /**< Windows Media Video format 7 */ OMX_VIDEO_WMVFormat7 = 0x02, /**< Windows Media Video format 7 */
OMX_VIDEO_WMVFormat8 = 0x04, /**< Windows Media Video format 8 */ OMX_VIDEO_WMVFormat8 = 0x04, /**< Windows Media Video format 8 */
OMX_VIDEO_WMVFormat9 = 0x08, /**< Windows Media Video format 9 */ OMX_VIDEO_WMVFormat9 = 0x08, /**< Windows Media Video format 9 */
OMX_VIDEO_WMFFormatKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */ OMX_VIDEO_WMFFormatKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */
OMX_VIDEO_WMFFormatVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */ OMX_VIDEO_WMFFormatVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */
OMX_VIDEO_WMVFormatMax = 0x7FFFFFFF OMX_VIDEO_WMVFormatMax = 0x7FFFFFFF
} OMX_VIDEO_WMVFORMATTYPE; } OMX_VIDEO_WMVFORMATTYPE;
/** /**
* WMV Params * WMV Params
* *
* STRUCT MEMBERS: * STRUCT MEMBERS:
* nSize : Size of the structure in bytes * nSize : Size of the structure in bytes
* nVersion : OMX specification version information * nVersion : OMX specification version information
* nPortIndex : Port that this structure applies to * nPortIndex : Port that this structure applies to
* eFormat : Version of WMV stream / data * eFormat : Version of WMV stream / data
*/ */
typedef struct OMX_VIDEO_PARAM_WMVTYPE { typedef struct OMX_VIDEO_PARAM_WMVTYPE {
OMX_U32 nSize; OMX_U32 nSize;
OMX_VERSIONTYPE nVersion; OMX_VERSIONTYPE nVersion;
OMX_U32 nPortIndex; OMX_U32 nPortIndex;
OMX_VIDEO_WMVFORMATTYPE eFormat; OMX_VIDEO_WMVFORMATTYPE eFormat;
} OMX_VIDEO_PARAM_WMVTYPE; } OMX_VIDEO_PARAM_WMVTYPE;
/** /**
* Real Video Version * Real Video Version
*/ */
typedef enum OMX_VIDEO_RVFORMATTYPE { typedef enum OMX_VIDEO_RVFORMATTYPE {
OMX_VIDEO_RVFormatUnused = 0, /**< Format unused or unknown */ OMX_VIDEO_RVFormatUnused = 0, /**< Format unused or unknown */
OMX_VIDEO_RVFormat8, /**< Real Video format 8 */ OMX_VIDEO_RVFormat8, /**< Real Video format 8 */
OMX_VIDEO_RVFormat9, /**< Real Video format 9 */ OMX_VIDEO_RVFormat9, /**< Real Video format 9 */
OMX_VIDEO_RVFormatG2, /**< Real Video Format G2 */ OMX_VIDEO_RVFormatG2, /**< Real Video Format G2 */
OMX_VIDEO_RVFormatKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */ OMX_VIDEO_RVFormatKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */
OMX_VIDEO_RVFormatVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */ OMX_VIDEO_RVFormatVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */
OMX_VIDEO_RVFormatMax = 0x7FFFFFFF OMX_VIDEO_RVFormatMax = 0x7FFFFFFF
} OMX_VIDEO_RVFORMATTYPE; } OMX_VIDEO_RVFORMATTYPE;
/** /**
* Real Video Params * Real Video Params
* *
* STUCT MEMBERS: * STUCT MEMBERS:
* nSize : Size of the structure in bytes * nSize : Size of the structure in bytes
* nVersion : OMX specification version information * nVersion : OMX specification version information
* nPortIndex : Port that this structure applies to * nPortIndex : Port that this structure applies to
* eFormat : Version of RV stream / data * eFormat : Version of RV stream / data
* nBitsPerPixel : Bits per pixel coded in the frame * nBitsPerPixel : Bits per pixel coded in the frame
* nPaddedWidth : Padded width in pixel of a video frame * nPaddedWidth : Padded width in pixel of a video frame
* nPaddedHeight : Padded Height in pixels of a video frame * nPaddedHeight : Padded Height in pixels of a video frame
* nFrameRate : Rate of video in frames per second * nFrameRate : Rate of video in frames per second
* nBitstreamFlags : Flags which internal information about the bitstream * nBitstreamFlags : Flags which internal information about the bitstream
* nBitstreamVersion : Bitstream version * nBitstreamVersion : Bitstream version
* nMaxEncodeFrameSize: Max encoded frame size * nMaxEncodeFrameSize: Max encoded frame size
* bEnablePostFilter : Turn on/off post filter * bEnablePostFilter : Turn on/off post filter
* bEnableTemporalInterpolation : Turn on/off temporal interpolation * bEnableTemporalInterpolation : Turn on/off temporal interpolation
* bEnableLatencyMode : When enabled, the decoder does not display a decoded * bEnableLatencyMode : When enabled, the decoder does not display a decoded
* frame until it has detected that no enhancement layer * frame until it has detected that no enhancement layer
* frames or dependent B frames will be coming. This * frames or dependent B frames will be coming. This
* detection usually occurs when a subsequent non-B * detection usually occurs when a subsequent non-B
* frame is encountered * frame is encountered
*/ */
typedef struct OMX_VIDEO_PARAM_RVTYPE { typedef struct OMX_VIDEO_PARAM_RVTYPE {
OMX_U32 nSize; OMX_U32 nSize;
OMX_VERSIONTYPE nVersion; OMX_VERSIONTYPE nVersion;
OMX_U32 nPortIndex; OMX_U32 nPortIndex;
OMX_VIDEO_RVFORMATTYPE eFormat; OMX_VIDEO_RVFORMATTYPE eFormat;
OMX_U16 nBitsPerPixel; OMX_U16 nBitsPerPixel;
OMX_U16 nPaddedWidth; OMX_U16 nPaddedWidth;
OMX_U16 nPaddedHeight; OMX_U16 nPaddedHeight;
OMX_U32 nFrameRate; OMX_U32 nFrameRate;
OMX_U32 nBitstreamFlags; OMX_U32 nBitstreamFlags;
OMX_U32 nBitstreamVersion; OMX_U32 nBitstreamVersion;
OMX_U32 nMaxEncodeFrameSize; OMX_U32 nMaxEncodeFrameSize;
OMX_BOOL bEnablePostFilter; OMX_BOOL bEnablePostFilter;
OMX_BOOL bEnableTemporalInterpolation; OMX_BOOL bEnableTemporalInterpolation;
OMX_BOOL bEnableLatencyMode; OMX_BOOL bEnableLatencyMode;
} OMX_VIDEO_PARAM_RVTYPE; } OMX_VIDEO_PARAM_RVTYPE;
/** /**
* AVC profile types, each profile indicates support for various * AVC profile types, each profile indicates support for various
* performance bounds and different annexes. * performance bounds and different annexes.
*/ */
typedef enum OMX_VIDEO_AVCPROFILETYPE { typedef enum OMX_VIDEO_AVCPROFILETYPE {
OMX_VIDEO_AVCProfileBaseline = 0x01, /**< Baseline profile */ OMX_VIDEO_AVCProfileBaseline = 0x01, /**< Baseline profile */
OMX_VIDEO_AVCProfileMain = 0x02, /**< Main profile */ OMX_VIDEO_AVCProfileMain = 0x02, /**< Main profile */
OMX_VIDEO_AVCProfileExtended = 0x04, /**< Extended profile */ OMX_VIDEO_AVCProfileExtended = 0x04, /**< Extended profile */
OMX_VIDEO_AVCProfileHigh = 0x08, /**< High profile */ OMX_VIDEO_AVCProfileHigh = 0x08, /**< High profile */
OMX_VIDEO_AVCProfileHigh10 = 0x10, /**< High 10 profile */ OMX_VIDEO_AVCProfileHigh10 = 0x10, /**< High 10 profile */
OMX_VIDEO_AVCProfileHigh422 = 0x20, /**< High 4:2:2 profile */ OMX_VIDEO_AVCProfileHigh422 = 0x20, /**< High 4:2:2 profile */
OMX_VIDEO_AVCProfileHigh444 = 0x40, /**< High 4:4:4 profile */ OMX_VIDEO_AVCProfileHigh444 = 0x40, /**< High 4:4:4 profile */
OMX_VIDEO_AVCProfileKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */ OMX_VIDEO_AVCProfileKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */
OMX_VIDEO_AVCProfileVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */ OMX_VIDEO_AVCProfileVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */
OMX_VIDEO_AVCProfileMax = 0x7FFFFFFF OMX_VIDEO_AVCProfileMax = 0x7FFFFFFF
} OMX_VIDEO_AVCPROFILETYPE; } OMX_VIDEO_AVCPROFILETYPE;
/** /**
* AVC level types, each level indicates support for various frame sizes, * AVC level types, each level indicates support for various frame sizes,
* bit rates, decoder frame rates. No need * bit rates, decoder frame rates. No need
*/ */
typedef enum OMX_VIDEO_AVCLEVELTYPE { typedef enum OMX_VIDEO_AVCLEVELTYPE {
OMX_VIDEO_AVCLevel1 = 0x01, /**< Level 1 */ OMX_VIDEO_AVCLevel1 = 0x01, /**< Level 1 */
OMX_VIDEO_AVCLevel1b = 0x02, /**< Level 1b */ OMX_VIDEO_AVCLevel1b = 0x02, /**< Level 1b */
OMX_VIDEO_AVCLevel11 = 0x04, /**< Level 1.1 */ OMX_VIDEO_AVCLevel11 = 0x04, /**< Level 1.1 */
OMX_VIDEO_AVCLevel12 = 0x08, /**< Level 1.2 */ OMX_VIDEO_AVCLevel12 = 0x08, /**< Level 1.2 */
OMX_VIDEO_AVCLevel13 = 0x10, /**< Level 1.3 */ OMX_VIDEO_AVCLevel13 = 0x10, /**< Level 1.3 */
OMX_VIDEO_AVCLevel2 = 0x20, /**< Level 2 */ OMX_VIDEO_AVCLevel2 = 0x20, /**< Level 2 */
OMX_VIDEO_AVCLevel21 = 0x40, /**< Level 2.1 */ OMX_VIDEO_AVCLevel21 = 0x40, /**< Level 2.1 */
OMX_VIDEO_AVCLevel22 = 0x80, /**< Level 2.2 */ OMX_VIDEO_AVCLevel22 = 0x80, /**< Level 2.2 */
OMX_VIDEO_AVCLevel3 = 0x100, /**< Level 3 */ OMX_VIDEO_AVCLevel3 = 0x100, /**< Level 3 */
OMX_VIDEO_AVCLevel31 = 0x200, /**< Level 3.1 */ OMX_VIDEO_AVCLevel31 = 0x200, /**< Level 3.1 */
OMX_VIDEO_AVCLevel32 = 0x400, /**< Level 3.2 */ OMX_VIDEO_AVCLevel32 = 0x400, /**< Level 3.2 */
OMX_VIDEO_AVCLevel4 = 0x800, /**< Level 4 */ OMX_VIDEO_AVCLevel4 = 0x800, /**< Level 4 */
OMX_VIDEO_AVCLevel41 = 0x1000, /**< Level 4.1 */ OMX_VIDEO_AVCLevel41 = 0x1000, /**< Level 4.1 */
OMX_VIDEO_AVCLevel42 = 0x2000, /**< Level 4.2 */ OMX_VIDEO_AVCLevel42 = 0x2000, /**< Level 4.2 */
OMX_VIDEO_AVCLevel5 = 0x4000, /**< Level 5 */ OMX_VIDEO_AVCLevel5 = 0x4000, /**< Level 5 */
OMX_VIDEO_AVCLevel51 = 0x8000, /**< Level 5.1 */ OMX_VIDEO_AVCLevel51 = 0x8000, /**< Level 5.1 */
OMX_VIDEO_AVCLevelKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */ OMX_VIDEO_AVCLevelKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */
OMX_VIDEO_AVCLevelVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */ OMX_VIDEO_AVCLevelVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */
OMX_VIDEO_AVCLevelMax = 0x7FFFFFFF OMX_VIDEO_AVCLevelMax = 0x7FFFFFFF
} OMX_VIDEO_AVCLEVELTYPE; } OMX_VIDEO_AVCLEVELTYPE;
/** /**
* AVC loop filter modes * AVC loop filter modes
* *
* OMX_VIDEO_AVCLoopFilterEnable : Enable * OMX_VIDEO_AVCLoopFilterEnable : Enable
* OMX_VIDEO_AVCLoopFilterDisable : Disable * OMX_VIDEO_AVCLoopFilterDisable : Disable
* OMX_VIDEO_AVCLoopFilterDisableSliceBoundary : Disabled on slice boundaries * OMX_VIDEO_AVCLoopFilterDisableSliceBoundary : Disabled on slice boundaries
*/ */
typedef enum OMX_VIDEO_AVCLOOPFILTERTYPE { typedef enum OMX_VIDEO_AVCLOOPFILTERTYPE {
OMX_VIDEO_AVCLoopFilterEnable = 0, OMX_VIDEO_AVCLoopFilterEnable = 0,
OMX_VIDEO_AVCLoopFilterDisable, OMX_VIDEO_AVCLoopFilterDisable,
OMX_VIDEO_AVCLoopFilterDisableSliceBoundary, OMX_VIDEO_AVCLoopFilterDisableSliceBoundary,
OMX_VIDEO_AVCLoopFilterKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */ OMX_VIDEO_AVCLoopFilterKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */
OMX_VIDEO_AVCLoopFilterVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */ OMX_VIDEO_AVCLoopFilterVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */
OMX_VIDEO_AVCLoopFilterMax = 0x7FFFFFFF OMX_VIDEO_AVCLoopFilterMax = 0x7FFFFFFF
} OMX_VIDEO_AVCLOOPFILTERTYPE; } OMX_VIDEO_AVCLOOPFILTERTYPE;
/** /**
* AVC params * AVC params
* *
* STRUCT MEMBERS: * STRUCT MEMBERS:
* nSize : Size of the structure in bytes * nSize : Size of the structure in bytes
* nVersion : OMX specification version information * nVersion : OMX specification version information
* nPortIndex : Port that this structure applies to * nPortIndex : Port that this structure applies to
* nSliceHeaderSpacing : Number of macroblocks between slice header, put * nSliceHeaderSpacing : Number of macroblocks between slice header, put
* zero if not used * zero if not used
* nPFrames : Number of P frames between each I frame * nPFrames : Number of P frames between each I frame
* nBFrames : Number of B frames between each I frame * nBFrames : Number of B frames between each I frame
* bUseHadamard : Enable/disable Hadamard transform * bUseHadamard : Enable/disable Hadamard transform
* nRefFrames : Max number of reference frames to use for inter * nRefFrames : Max number of reference frames to use for inter
* motion search (1-16) * motion search (1-16)
* nRefIdxTrailing : Pic param set ref frame index (index into ref * nRefIdxTrailing : Pic param set ref frame index (index into ref
* frame buffer of trailing frames list), B frame * frame buffer of trailing frames list), B frame
* support * support
* nRefIdxForward : Pic param set ref frame index (index into ref * nRefIdxForward : Pic param set ref frame index (index into ref
* frame buffer of forward frames list), B frame * frame buffer of forward frames list), B frame
* support * support
* bEnableUEP : Enable/disable unequal error protection. This * bEnableUEP : Enable/disable unequal error protection. This
* is only valid of data partitioning is enabled. * is only valid of data partitioning is enabled.
* bEnableFMO : Enable/disable flexible macroblock ordering * bEnableFMO : Enable/disable flexible macroblock ordering
* bEnableASO : Enable/disable arbitrary slice ordering * bEnableASO : Enable/disable arbitrary slice ordering
* bEnableRS : Enable/disable sending of redundant slices * bEnableRS : Enable/disable sending of redundant slices
* eProfile : AVC profile(s) to use * eProfile : AVC profile(s) to use
* eLevel : AVC level(s) to use * eLevel : AVC level(s) to use
* nAllowedPictureTypes : Specifies the picture types allowed in the * nAllowedPictureTypes : Specifies the picture types allowed in the
* bitstream * bitstream
* bFrameMBsOnly : specifies that every coded picture of the * bFrameMBsOnly : specifies that every coded picture of the
* coded video sequence is a coded frame * coded video sequence is a coded frame
* containing only frame macroblocks * containing only frame macroblocks
* bMBAFF : Enable/disable switching between frame and * bMBAFF : Enable/disable switching between frame and
* field macroblocks within a picture * field macroblocks within a picture
* bEntropyCodingCABAC : Entropy decoding method to be applied for the * bEntropyCodingCABAC : Entropy decoding method to be applied for the
* syntax elements for which two descriptors appear * syntax elements for which two descriptors appear
* in the syntax tables * in the syntax tables
* bWeightedPPrediction : Enable/disable weighted prediction shall not * bWeightedPPrediction : Enable/disable weighted prediction shall not
* be applied to P and SP slices * be applied to P and SP slices
* nWeightedBipredicitonMode : Default weighted prediction is applied to B * nWeightedBipredicitonMode : Default weighted prediction is applied to B
* slices * slices
* bconstIpred : Enable/disable intra prediction * bconstIpred : Enable/disable intra prediction
* bDirect8x8Inference : Specifies the method used in the derivation * bDirect8x8Inference : Specifies the method used in the derivation
* process for luma motion vectors for B_Skip, * process for luma motion vectors for B_Skip,
* B_Direct_16x16 and B_Direct_8x8 as specified * B_Direct_16x16 and B_Direct_8x8 as specified
* in subclause 8.4.1.2 of the AVC spec * in subclause 8.4.1.2 of the AVC spec
* bDirectSpatialTemporal : Flag indicating spatial or temporal direct * bDirectSpatialTemporal : Flag indicating spatial or temporal direct
* mode used in B slice coding (related to * mode used in B slice coding (related to
* bDirect8x8Inference) . Spatial direct mode is * bDirect8x8Inference) . Spatial direct mode is
* more common and should be the default. * more common and should be the default.
* nCabacInitIdx : Index used to init CABAC contexts * nCabacInitIdx : Index used to init CABAC contexts
* eLoopFilterMode : Enable/disable loop filter * eLoopFilterMode : Enable/disable loop filter
*/ */
typedef struct OMX_VIDEO_PARAM_AVCTYPE { typedef struct OMX_VIDEO_PARAM_AVCTYPE {
OMX_U32 nSize; OMX_U32 nSize;
OMX_VERSIONTYPE nVersion; OMX_VERSIONTYPE nVersion;
OMX_U32 nPortIndex; OMX_U32 nPortIndex;
OMX_U32 nSliceHeaderSpacing; OMX_U32 nSliceHeaderSpacing;
OMX_U32 nPFrames; OMX_U32 nPFrames;
OMX_U32 nBFrames; OMX_U32 nBFrames;
OMX_BOOL bUseHadamard; OMX_BOOL bUseHadamard;
OMX_U32 nRefFrames; OMX_U32 nRefFrames;
OMX_U32 nRefIdx10ActiveMinus1; OMX_U32 nRefIdx10ActiveMinus1;
OMX_U32 nRefIdx11ActiveMinus1; OMX_U32 nRefIdx11ActiveMinus1;
OMX_BOOL bEnableUEP; OMX_BOOL bEnableUEP;
OMX_BOOL bEnableFMO; OMX_BOOL bEnableFMO;
OMX_BOOL bEnableASO; OMX_BOOL bEnableASO;
OMX_BOOL bEnableRS; OMX_BOOL bEnableRS;
OMX_VIDEO_AVCPROFILETYPE eProfile; OMX_VIDEO_AVCPROFILETYPE eProfile;
OMX_VIDEO_AVCLEVELTYPE eLevel; OMX_VIDEO_AVCLEVELTYPE eLevel;
OMX_U32 nAllowedPictureTypes; OMX_U32 nAllowedPictureTypes;
OMX_BOOL bFrameMBsOnly; OMX_BOOL bFrameMBsOnly;
OMX_BOOL bMBAFF; OMX_BOOL bMBAFF;
OMX_BOOL bEntropyCodingCABAC; OMX_BOOL bEntropyCodingCABAC;
OMX_BOOL bWeightedPPrediction; OMX_BOOL bWeightedPPrediction;
OMX_U32 nWeightedBipredicitonMode; OMX_U32 nWeightedBipredicitonMode;
OMX_BOOL bconstIpred ; OMX_BOOL bconstIpred ;
OMX_BOOL bDirect8x8Inference; OMX_BOOL bDirect8x8Inference;
OMX_BOOL bDirectSpatialTemporal; OMX_BOOL bDirectSpatialTemporal;
OMX_U32 nCabacInitIdc; OMX_U32 nCabacInitIdc;
OMX_VIDEO_AVCLOOPFILTERTYPE eLoopFilterMode; OMX_VIDEO_AVCLOOPFILTERTYPE eLoopFilterMode;
} OMX_VIDEO_PARAM_AVCTYPE; } OMX_VIDEO_PARAM_AVCTYPE;
typedef struct OMX_VIDEO_PARAM_PROFILELEVELTYPE { typedef struct OMX_VIDEO_PARAM_PROFILELEVELTYPE {
OMX_U32 nSize; OMX_U32 nSize;
OMX_VERSIONTYPE nVersion; OMX_VERSIONTYPE nVersion;
OMX_U32 nPortIndex; OMX_U32 nPortIndex;
OMX_U32 eProfile; /**< type is OMX_VIDEO_AVCPROFILETYPE, OMX_VIDEO_H263PROFILETYPE, OMX_U32 eProfile; /**< type is OMX_VIDEO_AVCPROFILETYPE, OMX_VIDEO_H263PROFILETYPE,
or OMX_VIDEO_MPEG4PROFILETYPE depending on context */ or OMX_VIDEO_MPEG4PROFILETYPE depending on context */
OMX_U32 eLevel; /**< type is OMX_VIDEO_AVCLEVELTYPE, OMX_VIDEO_H263LEVELTYPE, OMX_U32 eLevel; /**< type is OMX_VIDEO_AVCLEVELTYPE, OMX_VIDEO_H263LEVELTYPE,
or OMX_VIDEO_MPEG4PROFILETYPE depending on context */ or OMX_VIDEO_MPEG4PROFILETYPE depending on context */
OMX_U32 nProfileIndex; /**< Used to query for individual profile support information, OMX_U32 nProfileIndex; /**< Used to query for individual profile support information,
This parameter is valid only for This parameter is valid only for
OMX_IndexParamVideoProfileLevelQuerySupported index, OMX_IndexParamVideoProfileLevelQuerySupported index,
For all other indices this parameter is to be ignored. */ For all other indices this parameter is to be ignored. */
} OMX_VIDEO_PARAM_PROFILELEVELTYPE; } OMX_VIDEO_PARAM_PROFILELEVELTYPE;
/** /**
* Structure for dynamically configuring bitrate mode of a codec. * Structure for dynamically configuring bitrate mode of a codec.
* *
* STRUCT MEMBERS: * STRUCT MEMBERS:
* nSize : Size of the struct in bytes * nSize : Size of the struct in bytes
* nVersion : OMX spec version info * nVersion : OMX spec version info
* nPortIndex : Port that this struct applies to * nPortIndex : Port that this struct applies to
* nEncodeBitrate : Target average bitrate to be generated in bps * nEncodeBitrate : Target average bitrate to be generated in bps
*/ */
typedef struct OMX_VIDEO_CONFIG_BITRATETYPE { typedef struct OMX_VIDEO_CONFIG_BITRATETYPE {
OMX_U32 nSize; OMX_U32 nSize;
OMX_VERSIONTYPE nVersion; OMX_VERSIONTYPE nVersion;
OMX_U32 nPortIndex; OMX_U32 nPortIndex;
OMX_U32 nEncodeBitrate; OMX_U32 nEncodeBitrate;
} OMX_VIDEO_CONFIG_BITRATETYPE; } OMX_VIDEO_CONFIG_BITRATETYPE;
/** /**
* Defines Encoder Frame Rate setting * Defines Encoder Frame Rate setting
* *
* STRUCT MEMBERS: * STRUCT MEMBERS:
* nSize : Size of the structure in bytes * nSize : Size of the structure in bytes
* nVersion : OMX specification version information * nVersion : OMX specification version information
* nPortIndex : Port that this structure applies to * nPortIndex : Port that this structure applies to
* xEncodeFramerate : Encoding framerate represented in Q16 format * xEncodeFramerate : Encoding framerate represented in Q16 format
*/ */
typedef struct OMX_CONFIG_FRAMERATETYPE { typedef struct OMX_CONFIG_FRAMERATETYPE {
OMX_U32 nSize; OMX_U32 nSize;
OMX_VERSIONTYPE nVersion; OMX_VERSIONTYPE nVersion;
OMX_U32 nPortIndex; OMX_U32 nPortIndex;
OMX_U32 xEncodeFramerate; /* Q16 format */ OMX_U32 xEncodeFramerate; /* Q16 format */
} OMX_CONFIG_FRAMERATETYPE; } OMX_CONFIG_FRAMERATETYPE;
typedef struct OMX_CONFIG_INTRAREFRESHVOPTYPE { typedef struct OMX_CONFIG_INTRAREFRESHVOPTYPE {
OMX_U32 nSize; OMX_U32 nSize;
OMX_VERSIONTYPE nVersion; OMX_VERSIONTYPE nVersion;
OMX_U32 nPortIndex; OMX_U32 nPortIndex;
OMX_BOOL IntraRefreshVOP; OMX_BOOL IntraRefreshVOP;
} OMX_CONFIG_INTRAREFRESHVOPTYPE; } OMX_CONFIG_INTRAREFRESHVOPTYPE;
typedef struct OMX_CONFIG_MACROBLOCKERRORMAPTYPE { typedef struct OMX_CONFIG_MACROBLOCKERRORMAPTYPE {
OMX_U32 nSize; OMX_U32 nSize;
OMX_VERSIONTYPE nVersion; OMX_VERSIONTYPE nVersion;
OMX_U32 nPortIndex; OMX_U32 nPortIndex;
OMX_U32 nErrMapSize; /* Size of the Error Map in bytes */ OMX_U32 nErrMapSize; /* Size of the Error Map in bytes */
OMX_U8 ErrMap[1]; /* Error map hint */ OMX_U8 ErrMap[1]; /* Error map hint */
} OMX_CONFIG_MACROBLOCKERRORMAPTYPE; } OMX_CONFIG_MACROBLOCKERRORMAPTYPE;
typedef struct OMX_CONFIG_MBERRORREPORTINGTYPE { typedef struct OMX_CONFIG_MBERRORREPORTINGTYPE {
OMX_U32 nSize; OMX_U32 nSize;
OMX_VERSIONTYPE nVersion; OMX_VERSIONTYPE nVersion;
OMX_U32 nPortIndex; OMX_U32 nPortIndex;
OMX_BOOL bEnabled; OMX_BOOL bEnabled;
} OMX_CONFIG_MBERRORREPORTINGTYPE; } OMX_CONFIG_MBERRORREPORTINGTYPE;
typedef struct OMX_PARAM_MACROBLOCKSTYPE { typedef struct OMX_PARAM_MACROBLOCKSTYPE {
OMX_U32 nSize; OMX_U32 nSize;
OMX_VERSIONTYPE nVersion; OMX_VERSIONTYPE nVersion;
OMX_U32 nPortIndex; OMX_U32 nPortIndex;
OMX_U32 nMacroblocks; OMX_U32 nMacroblocks;
} OMX_PARAM_MACROBLOCKSTYPE; } OMX_PARAM_MACROBLOCKSTYPE;
/** /**
* AVC Slice Mode modes * AVC Slice Mode modes
* *
* OMX_VIDEO_SLICEMODE_AVCDefault : Normal frame encoding, one slice per frame * OMX_VIDEO_SLICEMODE_AVCDefault : Normal frame encoding, one slice per frame
* OMX_VIDEO_SLICEMODE_AVCMBSlice : NAL mode, number of MBs per frame * OMX_VIDEO_SLICEMODE_AVCMBSlice : NAL mode, number of MBs per frame
* OMX_VIDEO_SLICEMODE_AVCByteSlice : NAL mode, number of bytes per frame * OMX_VIDEO_SLICEMODE_AVCByteSlice : NAL mode, number of bytes per frame
*/ */
typedef enum OMX_VIDEO_AVCSLICEMODETYPE { typedef enum OMX_VIDEO_AVCSLICEMODETYPE {
OMX_VIDEO_SLICEMODE_AVCDefault = 0, OMX_VIDEO_SLICEMODE_AVCDefault = 0,
OMX_VIDEO_SLICEMODE_AVCMBSlice, OMX_VIDEO_SLICEMODE_AVCMBSlice,
OMX_VIDEO_SLICEMODE_AVCByteSlice, OMX_VIDEO_SLICEMODE_AVCByteSlice,
OMX_VIDEO_SLICEMODE_AVCKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */ OMX_VIDEO_SLICEMODE_AVCKhronosExtensions = 0x6F000000, /**< Reserved region for introducing Khronos Standard Extensions */
OMX_VIDEO_SLICEMODE_AVCVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */ OMX_VIDEO_SLICEMODE_AVCVendorStartUnused = 0x7F000000, /**< Reserved region for introducing Vendor Extensions */
OMX_VIDEO_SLICEMODE_AVCLevelMax = 0x7FFFFFFF OMX_VIDEO_SLICEMODE_AVCLevelMax = 0x7FFFFFFF
} OMX_VIDEO_AVCSLICEMODETYPE; } OMX_VIDEO_AVCSLICEMODETYPE;
/** /**
* AVC FMO Slice Mode Params * AVC FMO Slice Mode Params
* *
* STRUCT MEMBERS: * STRUCT MEMBERS:
* nSize : Size of the structure in bytes * nSize : Size of the structure in bytes
* nVersion : OMX specification version information * nVersion : OMX specification version information
* nPortIndex : Port that this structure applies to * nPortIndex : Port that this structure applies to
* nNumSliceGroups : Specifies the number of slice groups * nNumSliceGroups : Specifies the number of slice groups
* nSliceGroupMapType : Specifies the type of slice groups * nSliceGroupMapType : Specifies the type of slice groups
* eSliceMode : Specifies the type of slice * eSliceMode : Specifies the type of slice
*/ */
typedef struct OMX_VIDEO_PARAM_AVCSLICEFMO { typedef struct OMX_VIDEO_PARAM_AVCSLICEFMO {
OMX_U32 nSize; OMX_U32 nSize;
OMX_VERSIONTYPE nVersion; OMX_VERSIONTYPE nVersion;
OMX_U32 nPortIndex; OMX_U32 nPortIndex;
OMX_U8 nNumSliceGroups; OMX_U8 nNumSliceGroups;
OMX_U8 nSliceGroupMapType; OMX_U8 nSliceGroupMapType;
OMX_VIDEO_AVCSLICEMODETYPE eSliceMode; OMX_VIDEO_AVCSLICEMODETYPE eSliceMode;
} OMX_VIDEO_PARAM_AVCSLICEFMO; } OMX_VIDEO_PARAM_AVCSLICEFMO;
/** /**
* AVC IDR Period Configs * AVC IDR Period Configs
* *
* STRUCT MEMBERS: * STRUCT MEMBERS:
* nSize : Size of the structure in bytes * nSize : Size of the structure in bytes
* nVersion : OMX specification version information * nVersion : OMX specification version information
* nPortIndex : Port that this structure applies to * nPortIndex : Port that this structure applies to
* nIDRPeriod : Specifies periodicity of IDR frames * nIDRPeriod : Specifies periodicity of IDR frames
* nPFrames : Specifies internal of coding Intra frames * nPFrames : Specifies internal of coding Intra frames
*/ */
typedef struct OMX_VIDEO_CONFIG_AVCINTRAPERIOD { typedef struct OMX_VIDEO_CONFIG_AVCINTRAPERIOD {
OMX_U32 nSize; OMX_U32 nSize;
OMX_VERSIONTYPE nVersion; OMX_VERSIONTYPE nVersion;
OMX_U32 nPortIndex; OMX_U32 nPortIndex;
OMX_U32 nIDRPeriod; OMX_U32 nIDRPeriod;
OMX_U32 nPFrames; OMX_U32 nPFrames;
} OMX_VIDEO_CONFIG_AVCINTRAPERIOD; } OMX_VIDEO_CONFIG_AVCINTRAPERIOD;
/** /**
* AVC NAL Size Configs * AVC NAL Size Configs
* *
* STRUCT MEMBERS: * STRUCT MEMBERS:
* nSize : Size of the structure in bytes * nSize : Size of the structure in bytes
* nVersion : OMX specification version information * nVersion : OMX specification version information
* nPortIndex : Port that this structure applies to * nPortIndex : Port that this structure applies to
* nNaluBytes : Specifies the NAL unit size * nNaluBytes : Specifies the NAL unit size
*/ */
typedef struct OMX_VIDEO_CONFIG_NALSIZE { typedef struct OMX_VIDEO_CONFIG_NALSIZE {
OMX_U32 nSize; OMX_U32 nSize;
OMX_VERSIONTYPE nVersion; OMX_VERSIONTYPE nVersion;
OMX_U32 nPortIndex; OMX_U32 nPortIndex;
OMX_U32 nNaluBytes; OMX_U32 nNaluBytes;
} OMX_VIDEO_CONFIG_NALSIZE; } OMX_VIDEO_CONFIG_NALSIZE;
/** @} */ /** @} */
#ifdef __cplusplus #ifdef __cplusplus
} }
#endif /* __cplusplus */ #endif /* __cplusplus */
#endif #endif
/* File EOF */ /* File EOF */
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment