blob: 102694d4e719b9ac0a1079877892d084052f0101 [file] [log] [blame]
/*
* Copyright (c) 2017, Intel Corporation
*
* Permission is hereby granted, free of charge, to any person obtaining a
* copy of this software and associated documentation files (the "Software"),
* to deal in the Software without restriction, including without limitation
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
* and/or sell copies of the Software, and to permit persons to whom the
* Software is furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included
* in all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
* OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
* THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR
* OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
* OTHER DEALINGS IN THE SOFTWARE.
*/
#ifndef CMRTLIB_LINUX_SHARE_CM_DEF_OS_H_
#define CMRTLIB_LINUX_SHARE_CM_DEF_OS_H_
#include "cm_include.h"
#include "cm_common.h"
#ifndef ANDROID
#include "va/va.h"
#else
#include <va/va_android.h>
#define Display unsigned int
#endif
#include <cstring>
#include "pthread.h"
#include <malloc.h>
////////////////////////////////////////////////////////////////////////////////////
// MS-specific defines/typedefs, which are absent under Linux but still used
////////////////////////////////////////////////////////////////////////////////////
#define _aligned_malloc(size, alignment) memalign(alignment, size)
#define _aligned_free(ptr) free(ptr)
typedef uint8_t BOOLEAN, *PBOOLEAN;
////////////////////////////////////////////////////////////////////////////////////
// MS-specific defines/typedefs, which are absent under Linux but still used (End)
////////////////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////////////////
// Platform dependent macros (Start)
////////////////////////////////////////////////////////////////////////////////////
#define CM_STRCPY(dst, sizeInBytes, src) strcpy(dst, src)
#define CM_STRNCPY(dst, sizeOfDst, src, count) strncpy(dst, src, count)
#define CM_STRCAT(dst, sizeOfDst, src) strcat(dst, src)
#define CM_GETENV(dst, name) dst = getenv(name)
#define CM_GETENV_FREE(dst)
#define CM_FOPEN(pFile, filename, mode) pFile = fopen(filename, mode)
#ifdef __cplusplus
# define EXTERN_C extern "C"
#else
# define EXTERN_C
#endif
#define SUCCEEDED(hr) (hr == VA_STATUS_SUCCESS)
#define FAILED(hr) (hr != VA_STATUS_SUCCESS)
typedef enum _VACMTEXTUREADDRESS {
VACMTADDRESS_WRAP = 1,
VACMTADDRESS_MIRROR = 2,
VACMTADDRESS_CLAMP = 3,
VACMTADDRESS_BORDER = 4,
VACMTADDRESS_MIRRORONCE = 5,
VACMTADDRESS_FORCE_DWORD = 0x7fffffff
} VACMTEXTUREADDRESS;
typedef enum _VACMTEXTUREFILTERTYPE {
VACMTEXF_NONE = 0,
VACMTEXF_POINT = 1,
VACMTEXF_LINEAR = 2,
VACMTEXF_ANISOTROPIC = 3,
VACMTEXF_FLATCUBIC = 4,
VACMTEXF_GAUSSIANCUBIC = 5,
VACMTEXF_PYRAMIDALQUAD = 6,
VACMTEXF_GAUSSIANQUAD = 7,
VACMTEXF_CONVOLUTIONMONO = 8, // Convolution filter for monochrome textures
VACMTEXF_FORCE_DWORD = 0x7fffffff
} VACMTEXTUREFILTERTYPE;
////////////////////////////////////////////////////////////////////////////////////
// Platform dependent macros (End)
////////////////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////////////////
// Platform dependent definitions (Start)
////////////////////////////////////////////////////////////////////////////////////
#define VAExtModuleCMRT 2
#define CM_MAX_SURFACE2D_FORMAT_COUNT 47
inline void * CM_ALIGNED_MALLOC(size_t size, size_t alignment)
{
return memalign(alignment, size);
}
inline void CM_ALIGNED_FREE(void * memory)
{
free(memory);
}
// max resolution for surface 2D
#define CM_MAX_2D_SURF_WIDTH 16384
#define CM_MAX_2D_SURF_HEIGHT 16384
typedef enum _VA_CM_FORMAT {
VA_CM_FMT_UNKNOWN = 0,
VA_CM_FMT_A8R8G8B8 = 21,
VA_CM_FMT_X8R8G8B8 = 22,
VA_CM_FMT_A8 = 28,
VA_CM_FMT_A2B10G10R10 = 31,
VA_CM_FMT_A8B8G8R8 = 32,
VA_CM_FMT_R16G16UN = 35,
VA_CM_FMT_A16B16G16R16 = 36,
VA_CM_FMT_A8P8 = 40,
VA_CM_FMT_P8 = 41,
VA_CM_FMT_R32U = 42,
VA_CM_FMT_R8G8UN = 49,
VA_CM_FMT_L8 = 50,
VA_CM_FMT_A8L8 = 51,
VA_CM_FMT_R16UN = 56,
VA_CM_FMT_R16U = 57,
VA_CM_FMT_V8U8 = 60,
VA_CM_FMT_R8UN = 61,
VA_CM_FMT_R8U = 62,
VA_CM_FMT_R32S = 71,
VA_CM_FMT_D16 = 80,
VA_CM_FMT_L16 = 81,
VA_CM_FMT_R16F = 111,
VA_CM_FMT_IA44 = 112,
VA_CM_FMT_A16B16G16R16F = 113,
VA_CM_FMT_R32F = 114,
VA_CM_FMT_R32G32B32A32F = 115,
VA_CM_FMT_I420 = VA_FOURCC('I','4','2','0'),
VA_CM_FMT_P216 = VA_FOURCC('P','2','1','6'),
VA_CM_FMT_400P = VA_FOURCC('4','0','0','P'),
VA_CM_FMT_Y8UN = VA_FOURCC('Y','8','U','N'),
VA_CM_FMT_NV12 = VA_FOURCC_NV12,
VA_CM_FMT_UYVY = VA_FOURCC_UYVY,
VA_CM_FMT_YUY2 = VA_FOURCC_YUY2,
VA_CM_FMT_444P = VA_FOURCC_444P,
VA_CM_FMT_411P = VA_FOURCC_411P,
VA_CM_FMT_422H = VA_FOURCC_422H,
VA_CM_FMT_422V = VA_FOURCC_422V,
VA_CM_FMT_411R = VA_FOURCC_411R,
VA_CM_FMT_RGBP = VA_FOURCC_RGBP,
VA_CM_FMT_BGRP = VA_FOURCC_BGRP,
VA_CM_FMT_IMC3 = VA_FOURCC_IMC3,
VA_CM_FMT_YV12 = VA_FOURCC_YV12,
VA_CM_FMT_P010 = VA_FOURCC_P010,
VA_CM_FMT_P012 = VA_FOURCC_P012,
VA_CM_FMT_P016 = VA_FOURCC_P016,
VA_CM_FMT_P208 = VA_FOURCC_P208,
VA_CM_FMT_AYUV = VA_FOURCC_AYUV,
VA_CM_FMT_Y210 = VA_FOURCC_Y210,
#if VA_CHECK_VERSION(1, 9, 0)
VA_CM_FMT_Y212 = VA_FOURCC_Y212,
#endif
VA_CM_FMT_Y410 = VA_FOURCC_Y410,
#if VA_CHECK_VERSION(1, 9, 0)
VA_CM_FMT_Y412 = VA_FOURCC_Y412,
#endif
VA_CM_FMT_Y216 = VA_FOURCC_Y216,
VA_CM_FMT_Y416 = VA_FOURCC_Y416,
VA_CM_FMT_AI44 = VA_FOURCC_AI44,
VA_CM_FMT_MAX = 0xFFFFFFFF
} VA_CM_FORMAT;
#define CM_SURFACE_FORMAT VA_CM_FORMAT
#define CM_SURFACE_FORMAT_UNKNOWN VA_CM_FMT_UNKNOWN
#define CM_SURFACE_FORMAT_A8R8G8B8 VA_CM_FMT_A8R8G8B8
#define CM_SURFACE_FORMAT_X8R8G8B8 VA_CM_FMT_X8R8G8B8
#define CM_SURFACE_FORMAT_A8B8G8R8 VA_CM_FMT_A8B8G8R8
#define CM_SURFACE_FORMAT_A8 VA_CM_FMT_A8
#define CM_SURFACE_FORMAT_P8 VA_CM_FMT_P8
#define CM_SURFACE_FORMAT_R32F VA_CM_FMT_R32F
#define CM_SURFACE_FORMAT_NV12 VA_CM_FMT_NV12
#define CM_SURFACE_FORMAT_UYVY VA_CM_FMT_UYVY
#define CM_SURFACE_FORMAT_YUY2 VA_CM_FMT_YUY2
#define CM_SURFACE_FORMAT_V8U8 VA_CM_FMT_V8U8
#define CM_SURFACE_FORMAT_R8_UINT VA_CM_FMT_R8U
#define CM_SURFACE_FORMAT_R16_SINT VA_CM_FMT_A8L8
#define CM_SURFACE_FORMAT_R16_UINT VA_CM_FMT_R16U
#define CM_SURFACE_FORMAT_D16 VA_CM_FMT_D16
#define CM_SURFACE_FORMAT_L16 VA_CM_FMT_L16
#define CM_SURFACE_FORMAT_A16B16G16R16 VA_CM_FMT_A16B16G16R16
#define CM_SURFACE_FORMAT_R10G10B10A2 VA_CM_FMT_A2B10G10R10
#define CM_SURFACE_FORMAT_A16B16G16R16F VA_CM_FMT_A16B16G16R16F
#define CM_SURFACE_FORMAT_R32G32B32A32F VA_CM_FMT_R32G32B32A32F
#define CM_SURFACE_FORMAT_444P VA_CM_FMT_444P
#define CM_SURFACE_FORMAT_422H VA_CM_FMT_422H
#define CM_SURFACE_FORMAT_422V VA_CM_FMT_422V
#define CM_SURFACE_FORMAT_411P VA_CM_FMT_411P
#define CM_SURFACE_FORMAT_411R VA_CM_FMT_411R
#define CM_SURFACE_FORMAT_RGBP VA_CM_FMT_RGBP
#define CM_SURFACE_FORMAT_BGRP VA_CM_FMT_BGRP
#define CM_SURFACE_FORMAT_IMC3 VA_CM_FMT_IMC3
#define CM_SURFACE_FORMAT_YV12 VA_CM_FMT_YV12
#define CM_SURFACE_FORMAT_P010 VA_CM_FMT_P010
#define CM_SURFACE_FORMAT_P016 VA_CM_FMT_P016
#define CM_SURFACE_FORMAT_P208 VA_CM_FMT_P208
#define CM_SURFACE_FORMAT_AYUV VA_CM_FMT_AYUV
#define CM_SURFACE_FORMAT_Y210 VA_CM_FMT_Y210
#define CM_SURFACE_FORMAT_Y410 VA_CM_FMT_Y410
#define CM_SURFACE_FORMAT_Y216 VA_CM_FMT_Y216
#define CM_SURFACE_FORMAT_Y416 VA_CM_FMT_Y416
#define CM_SURFACE_FORMAT_IA44 VA_CM_FMT_IA44
#define CM_SURFACE_FORMAT_AI44 VA_CM_FMT_AI44
#define CM_SURFACE_FORMAT_I420 VA_CM_FMT_I420
#define CM_SURFACE_FORMAT_P216 VA_CM_FMT_P216
#define CM_SURFACE_FORMAT_400P VA_CM_FMT_400P
#define CM_SURFACE_FORMAT_R16_FLOAT VA_CM_FMT_R16F
#define CM_SURFACE_FORMAT_Y8_UNORM VA_CM_FMT_Y8UN
#define CM_SURFACE_FORMAT_A8P8 VA_CM_FMT_A8P8
#define CM_SURFACE_FORMAT_R32_SINT VA_CM_FMT_R32S
#define CM_SURFACE_FORMAT_R32_UINT VA_CM_FMT_R32U
#define CM_SURFACE_FORMAT_R8G8_UNORM VA_CM_FMT_R8G8UN
#define CM_SURFACE_FORMAT_R8_UNORM VA_CM_FMT_R8UN
#define CM_SURFACE_FORMAT_R16G16_UNORM VA_CM_FMT_R16G16UN
#define CM_SURFACE_FORMAT_R16_UNORM VA_CM_FMT_R16UN
#define CM_TEXTURE_ADDRESS_TYPE VACMTEXTUREADDRESS
#define CM_TEXTURE_ADDRESS_WRAP VACMTADDRESS_WRAP
#define CM_TEXTURE_ADDRESS_MIRROR VACMTADDRESS_MIRROR
#define CM_TEXTURE_ADDRESS_CLAMP VACMTADDRESS_CLAMP
#define CM_TEXTURE_ADDRESS_BORDER VACMTADDRESS_BORDER
#define CM_TEXTURE_ADDRESS_MIRRORONCE VACMTADDRESS_MIRRORONCE
#define CM_TEXTURE_FILTER_TYPE VACMTEXTUREFILTERTYPE
#define CM_TEXTURE_FILTER_TYPE_NONE VACMTEXF_NONE
#define CM_TEXTURE_FILTER_TYPE_POINT VACMTEXF_POINT
#define CM_TEXTURE_FILTER_TYPE_LINEAR VACMTEXF_LINEAR
#define CM_TEXTURE_FILTER_TYPE_ANISOTROPIC VACMTEXF_ANISOTROPIC
#define CM_TEXTURE_FILTER_TYPE_FLATCUBIC VACMTEXF_FLATCUBIC
#define CM_TEXTURE_FILTER_TYPE_GAUSSIANCUBIC VACMTEXF_GAUSSIANCUBIC
#define CM_TEXTURE_FILTER_TYPE_PYRAMIDALQUAD VACMTEXF_PYRAMIDALQUAD
#define CM_TEXTURE_FILTER_TYPE_GAUSSIANQUAD VACMTEXF_GAUSSIANQUAD
#define CM_TEXTURE_FILTER_TYPE_CONVOLUTIONMONO VACMTEXF_CONVOLUTIONMONO
////////////////////////////////////////////////////////////////////////////////////
// Platform dependent definitions (End)
////////////////////////////////////////////////////////////////////////////////////
typedef enum _AdapterInfoType
{
Description, // char Description[ 256 ];
VendorId, // uint32_t VendorId;
DeviceId, // uint32_t DeviceId;
SubSysId, // uint32_t SubSysId;
Revision, // uint32_t Revision;
DedicatedVideoMemory, // uint32_t DedicatedVideoMemory;
DedicatedSystemMemory, // uint32_t DedicatedSystemMemory;
SharedSystemMemory, // uint32_t SharedSystemMemory;
MaxThread, // uint32_t hardware thread count
EuNumber, // uint32_t EU count
TileNumber, // uint32_t Tile count
Reserved // uint32_t
} AdapterInfoType;
typedef enum _REGISTRATION_OP
{
REG_IGNORE = 0,
REG_REGISTER = 1,
REG_UNREGISTER = 2,
REG_REGISTER_INDEX = 3 // Register surface for Cm
} REGISTRATION_OP;
class CSync
{
public:
CSync() { pthread_mutex_init(&m_criticalSection, nullptr); }
~CSync() { pthread_mutex_destroy(&m_criticalSection); }
void Acquire() { pthread_mutex_lock(&m_criticalSection); }
void Release() {pthread_mutex_unlock(&m_criticalSection); }
private:
pthread_mutex_t m_criticalSection;
};
//The communication function for CM to call into UMD, get function pointer by libVA::vaGetLibFunc()
typedef VAStatus (__cdecl *pvaCmExtSendReqMsg)(VADisplay dpy, void *moduleType,
uint32_t *inputFunId, void *inputData, uint32_t *inputDataLen,
uint32_t *outputFunId, void *outputData, uint32_t *outputDataLen);
typedef struct _CM_CREATESURFACE2D_PARAM
{
uint32_t width; // [in] width of 2D texture in pixel
uint32_t height; // [in] height of 2D texture in pixel
CM_SURFACE_FORMAT format; // [in] DXGI format of 2D texture
union
{
uint32_t index2DinLookupTable; // [in] surface 2d's index in look up table.
uint32_t vaSurfaceID; // [in] libva-surface 2d's index in media driver
};
VASurfaceID *vaSurface; // [in] Pointer to a Libva Surface.
void *cmSurface2DHandle; // [out] pointer of CmSurface2D used in driver
bool isCmCreated;
int32_t returnValue; // [out] the return value from driver
bool isLibvaCreated; // [in] if the surface created via libva
void *vaDpy; // [in] VaDisplay used to free va sruface
}CM_CREATESURFACE2D_PARAM, *PCM_CREATESURFACE2D_PARAM;
//The communication function for CM to call into UMD, get function pointer by libVA::vaGetLibFunc()
typedef VAStatus (__cdecl *pvaCmExtSendReqMsg)(
VADisplay dpy,
void *moduleType,
uint32_t *inputFunId,
void *inputData,
uint32_t *inputDataLen,
uint32_t *outputFunId,
void *outputData,
uint32_t *outputDataLen);
typedef VADisplay (*pfVAGetDisplayDRM) (int32_t fd); //vaGetDisplayDRM from libva-drm.so
#ifndef CMRT_NOINLINE
#define CMRT_NOINLINE __attribute__((noinline))
#endif
#ifdef _DEBUG
#define CmAssert(expr) \
if( !(expr) ) \
{ \
__builtin_trap(); \
}
#else
#define CmAssert(expr)
#endif
typedef void *HMODULE;
#endif // #ifndef CMRTLIB_LINUX_SHARE_CM_DEF_OS_H_