Data.h 9.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177
  1. //
  2. // Notice Regarding Standards. AMD does not provide a license or sublicense to
  3. // any Intellectual Property Rights relating to any standards, including but not
  4. // limited to any audio and/or video codec technologies such as MPEG-2, MPEG-4;
  5. // AVC/H.264; HEVC/H.265; AAC decode/FFMPEG; AAC encode/FFMPEG; VC-1; and MP3
  6. // (collectively, the "Media Technologies"). For clarity, you will pay any
  7. // royalties due for such third party technologies, which may include the Media
  8. // Technologies that are owed as a result of AMD providing the Software to you.
  9. //
  10. // MIT license
  11. //
  12. // Copyright (c) 2018 Advanced Micro Devices, Inc. All rights reserved.
  13. //
  14. // Permission is hereby granted, free of charge, to any person obtaining a copy
  15. // of this software and associated documentation files (the "Software"), to deal
  16. // in the Software without restriction, including without limitation the rights
  17. // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
  18. // copies of the Software, and to permit persons to whom the Software is
  19. // furnished to do so, subject to the following conditions:
  20. //
  21. // The above copyright notice and this permission notice shall be included in
  22. // all copies or substantial portions of the Software.
  23. //
  24. // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  25. // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  26. // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
  27. // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  28. // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
  29. // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
  30. // THE SOFTWARE.
  31. //
  32. #ifndef AMF_Data_h
  33. #define AMF_Data_h
  34. #pragma once
  35. #include "PropertyStorage.h"
  36. #if defined(__cplusplus)
  37. namespace amf
  38. {
  39. #endif
  40. //----------------------------------------------------------------------------------------------
  41. typedef enum AMF_DATA_TYPE
  42. {
  43. AMF_DATA_BUFFER = 0,
  44. AMF_DATA_SURFACE = 1,
  45. AMF_DATA_AUDIO_BUFFER = 2,
  46. AMF_DATA_USER = 1000,
  47. // all extensions will be AMF_DATA_USER+i
  48. } AMF_DATA_TYPE;
  49. //----------------------------------------------------------------------------------------------
  50. typedef enum AMF_MEMORY_TYPE
  51. {
  52. AMF_MEMORY_UNKNOWN = 0,
  53. AMF_MEMORY_HOST = 1,
  54. AMF_MEMORY_DX9 = 2,
  55. AMF_MEMORY_DX11 = 3,
  56. AMF_MEMORY_OPENCL = 4,
  57. AMF_MEMORY_OPENGL = 5,
  58. AMF_MEMORY_XV = 6,
  59. AMF_MEMORY_GRALLOC = 7,
  60. AMF_MEMORY_COMPUTE_FOR_DX9 = 8, // deprecated, the same as AMF_MEMORY_OPENCL
  61. AMF_MEMORY_COMPUTE_FOR_DX11 = 9, // deprecated, the same as AMF_MEMORY_OPENCL
  62. AMF_MEMORY_VULKAN = 10,
  63. AMF_MEMORY_DX12 = 11,
  64. } AMF_MEMORY_TYPE;
  65. //----------------------------------------------------------------------------------------------
  66. typedef enum AMF_DX_VERSION
  67. {
  68. AMF_DX9 = 90,
  69. AMF_DX9_EX = 91,
  70. AMF_DX11_0 = 110,
  71. AMF_DX11_1 = 111,
  72. AMF_DX12 = 120,
  73. } AMF_DX_VERSION;
  74. //----------------------------------------------------------------------------------------------
  75. // AMF_MEMORY_CPU_ACCESS translates to D3D11_CPU_ACCESS_FLAG or VkImageUsageFlags
  76. // bit mask
  77. //----------------------------------------------------------------------------------------------
  78. typedef enum AMF_MEMORY_CPU_ACCESS_BITS
  79. { // D3D11 D3D12 Vulkan
  80. AMF_MEMORY_CPU_DEFAULT = 0x80000000, // 0 , D3D12_HEAP_TYPE_DEFAULT , VK_MEMORY_PROPERTY_HOST_VISIBLE_BIT | VK_MEMORY_PROPERTY_DEVICE_LOCAL_BIT
  81. AMF_MEMORY_CPU_NONE = 0x00000000, // 0 , D3D12_HEAP_TYPE_DEFAULT ,
  82. AMF_MEMORY_CPU_READ = 0x00000001, // D3D11_CPU_ACCESS_READ , D3D12_HEAP_TYPE_READBACK, VK_MEMORY_PROPERTY_HOST_VISIBLE_BIT
  83. AMF_MEMORY_CPU_WRITE = 0x00000002, // D3D11_CPU_ACCESS_WRITE, D3D12_HEAP_TYPE_UPLOAD , VK_MEMORY_PROPERTY_HOST_VISIBLE_BIT
  84. AMF_MEMORY_CPU_LOCAL = 0x00000004, // , D3D12_HEAP_TYPE_DEFAULT , VK_MEMORY_PROPERTY_DEVICE_LOCAL_BIT
  85. AMF_MEMORY_CPU_PINNED = 0x00000008, // , , VK_EXTERNAL_MEMORY_FEATURE_IMPORTABLE_BIT_KHR
  86. } AMF_MEMORY_CPU_ACCESS_BITS;
  87. typedef amf_flags AMF_MEMORY_CPU_ACCESS;
  88. //----------------------------------------------------------------------------------------------
  89. // AMFData interface
  90. //----------------------------------------------------------------------------------------------
  91. #if defined(__cplusplus)
  92. class AMF_NO_VTABLE AMFData : public AMFPropertyStorage
  93. {
  94. public:
  95. AMF_DECLARE_IID(0xa1159bf6, 0x9104, 0x4107, 0x8e, 0xaa, 0xc5, 0x3d, 0x5d, 0xba, 0xc5, 0x11)
  96. virtual AMF_MEMORY_TYPE AMF_STD_CALL GetMemoryType() = 0;
  97. virtual AMF_RESULT AMF_STD_CALL Duplicate(AMF_MEMORY_TYPE type, AMFData** ppData) = 0;
  98. virtual AMF_RESULT AMF_STD_CALL Convert(AMF_MEMORY_TYPE type) = 0; // optimal interop if possilble. Copy through host memory if needed
  99. virtual AMF_RESULT AMF_STD_CALL Interop(AMF_MEMORY_TYPE type) = 0; // only optimal interop if possilble. No copy through host memory for GPU objects
  100. virtual AMF_DATA_TYPE AMF_STD_CALL GetDataType() = 0;
  101. virtual amf_bool AMF_STD_CALL IsReusable() = 0;
  102. virtual void AMF_STD_CALL SetPts(amf_pts pts) = 0;
  103. virtual amf_pts AMF_STD_CALL GetPts() = 0;
  104. virtual void AMF_STD_CALL SetDuration(amf_pts duration) = 0;
  105. virtual amf_pts AMF_STD_CALL GetDuration() = 0;
  106. };
  107. //----------------------------------------------------------------------------------------------
  108. // smart pointer
  109. //----------------------------------------------------------------------------------------------
  110. typedef AMFInterfacePtr_T<AMFData> AMFDataPtr;
  111. //----------------------------------------------------------------------------------------------
  112. #else // #if defined(__cplusplus)
  113. typedef struct AMFData AMFData;
  114. AMF_DECLARE_IID(AMFData, 0xa1159bf6, 0x9104, 0x4107, 0x8e, 0xaa, 0xc5, 0x3d, 0x5d, 0xba, 0xc5, 0x11)
  115. typedef struct AMFDataVtbl
  116. {
  117. // AMFInterface interface
  118. amf_long (AMF_STD_CALL *Acquire)(AMFData* pThis);
  119. amf_long (AMF_STD_CALL *Release)(AMFData* pThis);
  120. enum AMF_RESULT (AMF_STD_CALL *QueryInterface)(AMFData* pThis, const struct AMFGuid *interfaceID, void** ppInterface);
  121. // AMFPropertyStorage interface
  122. AMF_RESULT (AMF_STD_CALL *SetProperty)(AMFData* pThis, const wchar_t* name, AMFVariantStruct value);
  123. AMF_RESULT (AMF_STD_CALL *GetProperty)(AMFData* pThis, const wchar_t* name, AMFVariantStruct* pValue);
  124. amf_bool (AMF_STD_CALL *HasProperty)(AMFData* pThis, const wchar_t* name);
  125. amf_size (AMF_STD_CALL *GetPropertyCount)(AMFData* pThis);
  126. AMF_RESULT (AMF_STD_CALL *GetPropertyAt)(AMFData* pThis, amf_size index, wchar_t* name, amf_size nameSize, AMFVariantStruct* pValue);
  127. AMF_RESULT (AMF_STD_CALL *Clear)(AMFData* pThis);
  128. AMF_RESULT (AMF_STD_CALL *AddTo)(AMFData* pThis, AMFPropertyStorage* pDest, amf_bool overwrite, amf_bool deep);
  129. AMF_RESULT (AMF_STD_CALL *CopyTo)(AMFData* pThis, AMFPropertyStorage* pDest, amf_bool deep);
  130. void (AMF_STD_CALL *AddObserver)(AMFData* pThis, AMFPropertyStorageObserver* pObserver);
  131. void (AMF_STD_CALL *RemoveObserver)(AMFData* pThis, AMFPropertyStorageObserver* pObserver);
  132. // AMFData interface
  133. AMF_MEMORY_TYPE (AMF_STD_CALL *GetMemoryType)(AMFData* pThis);
  134. AMF_RESULT (AMF_STD_CALL *Duplicate)(AMFData* pThis, AMF_MEMORY_TYPE type, AMFData** ppData);
  135. AMF_RESULT (AMF_STD_CALL *Convert)(AMFData* pThis, AMF_MEMORY_TYPE type); // optimal interop if possilble. Copy through host memory if needed
  136. AMF_RESULT (AMF_STD_CALL *Interop)(AMFData* pThis, AMF_MEMORY_TYPE type); // only optimal interop if possilble. No copy through host memory for GPU objects
  137. AMF_DATA_TYPE (AMF_STD_CALL *GetDataType)(AMFData* pThis);
  138. amf_bool (AMF_STD_CALL *IsReusable)(AMFData* pThis);
  139. void (AMF_STD_CALL *SetPts)(AMFData* pThis, amf_pts pts);
  140. amf_pts (AMF_STD_CALL *GetPts)(AMFData* pThis);
  141. void (AMF_STD_CALL *SetDuration)(AMFData* pThis, amf_pts duration);
  142. amf_pts (AMF_STD_CALL *GetDuration)(AMFData* pThis);
  143. } AMFDataVtbl;
  144. struct AMFData
  145. {
  146. const AMFDataVtbl *pVtbl;
  147. };
  148. #endif // #if defined(__cplusplus)
  149. #if defined(__cplusplus)
  150. } // namespace
  151. #endif
  152. #endif //#ifndef AMF_Data_h