gpu_info_oneapi.h 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211
  1. #ifndef __APPLE__
  2. #ifndef __GPU_INFO_ONEAPI_H__
  3. #define __GPU_INFO_ONEAPI_H__
  4. #include "gpu_info.h"
  5. #define ZE_MAX_DEVICE_NAME 256
  6. #define ZE_MAX_DEVICE_UUID_SIZE 16
  7. #define ZES_STRING_PROPERTY_SIZE 64
  8. #define ZE_BIT(_i) (1 << _i)
  9. // Just enough typedef's to dlopen/dlsym for memory information
  10. typedef enum ze_result_t
  11. {
  12. ZE_RESULT_SUCCESS = 0,
  13. // Other values omitted for now...
  14. } ze_result_t;
  15. typedef uint8_t ze_bool_t;
  16. typedef struct _zes_driver_handle_t *zes_driver_handle_t;
  17. typedef struct _zes_device_handle_t *zes_device_handle_t;
  18. typedef struct _zes_mem_handle_t *zes_mem_handle_t;
  19. typedef enum _ze_structure_type_t
  20. {
  21. ZE_STRUCTURE_TYPE_FORCE_UINT32 = 0x7fffffff
  22. } ze_structure_type_t;
  23. typedef enum _zes_structure_type_t
  24. {
  25. ZES_STRUCTURE_TYPE_DEVICE_PROPERTIES = 0x1,
  26. ZES_STRUCTURE_TYPE_MEM_PROPERTIES = 0xb,
  27. ZES_STRUCTURE_TYPE_MEM_STATE = 0x1e,
  28. ZES_STRUCTURE_TYPE_DEVICE_EXT_PROPERTIES = 0x2d,
  29. ZES_STRUCTURE_TYPE_FORCE_UINT32 = 0x7fffffff
  30. } zes_structure_type_t;
  31. typedef enum _zes_mem_type_t
  32. {
  33. ZES_MEM_TYPE_FORCE_UINT32 = 0x7fffffff
  34. } zes_mem_type_t;
  35. typedef enum _zes_mem_loc_t
  36. {
  37. ZES_MEM_LOC_SYSTEM = 0,
  38. ZES_MEM_LOC_DEVICE = 1,
  39. ZES_MEM_LOC_FORCE_UINT32 = 0x7fffffff
  40. } zes_mem_loc_t;
  41. typedef enum _zes_mem_health_t
  42. {
  43. ZES_MEM_HEALTH_FORCE_UINT32 = 0x7fffffff
  44. } zes_mem_health_t;
  45. typedef struct _ze_device_uuid_t
  46. {
  47. uint8_t id[ZE_MAX_DEVICE_UUID_SIZE];
  48. } ze_device_uuid_t;
  49. typedef struct _zes_uuid_t
  50. {
  51. uint8_t id[ZE_MAX_DEVICE_UUID_SIZE];
  52. } zes_uuid_t;
  53. typedef enum _ze_device_type_t
  54. {
  55. ZE_DEVICE_TYPE_GPU = 1,
  56. ZE_DEVICE_TYPE_CPU = 2,
  57. ZE_DEVICE_TYPE_FPGA = 3,
  58. ZE_DEVICE_TYPE_MCA = 4,
  59. ZE_DEVICE_TYPE_VPU = 5,
  60. ZE_DEVICE_TYPE_FORCE_UINT32 = 0x7fffffff
  61. } ze_device_type_t;
  62. typedef enum _zes_device_type_t
  63. {
  64. ZES_DEVICE_TYPE_GPU = 1,
  65. ZES_DEVICE_TYPE_CPU = 2,
  66. ZES_DEVICE_TYPE_FPGA = 3,
  67. ZES_DEVICE_TYPE_MCA = 4,
  68. ZES_DEVICE_TYPE_VPU = 5,
  69. ZES_DEVICE_TYPE_FORCE_UINT32 = 0x7fffffff
  70. } zes_device_type_t;
  71. typedef uint32_t ze_device_property_flags_t;
  72. typedef enum _ze_device_property_flag_t
  73. {
  74. ZE_DEVICE_PROPERTY_FLAG_INTEGRATED = ZE_BIT(0),
  75. ZE_DEVICE_PROPERTY_FLAG_SUBDEVICE = ZE_BIT(1),
  76. ZE_DEVICE_PROPERTY_FLAG_ECC = ZE_BIT(2),
  77. ZE_DEVICE_PROPERTY_FLAG_ONDEMANDPAGING = ZE_BIT(3),
  78. ZE_DEVICE_PROPERTY_FLAG_FORCE_UINT32 = 0x7fffffff
  79. } ze_device_property_flag_t;
  80. typedef uint32_t zes_device_property_flags_t;
  81. typedef enum _zes_device_property_flag_t
  82. {
  83. ZES_DEVICE_PROPERTY_FLAG_INTEGRATED = ZE_BIT(0),
  84. ZES_DEVICE_PROPERTY_FLAG_SUBDEVICE = ZE_BIT(1),
  85. ZES_DEVICE_PROPERTY_FLAG_ECC = ZE_BIT(2),
  86. ZES_DEVICE_PROPERTY_FLAG_ONDEMANDPAGING = ZE_BIT(3),
  87. ZES_DEVICE_PROPERTY_FLAG_FORCE_UINT32 = 0x7fffffff
  88. } zes_device_property_flag_t;
  89. typedef struct _ze_device_properties_t
  90. {
  91. ze_structure_type_t stype;
  92. void *pNext;
  93. ze_device_type_t type;
  94. uint32_t vendorId;
  95. uint32_t deviceId;
  96. ze_device_property_flags_t flags;
  97. uint32_t subdeviceId;
  98. uint32_t coreClockRate;
  99. uint64_t maxMemAllocSize;
  100. uint32_t maxHardwareContexts;
  101. uint32_t maxCommandQueuePriority;
  102. uint32_t numThreadsPerEU;
  103. uint32_t physicalEUSimdWidth;
  104. uint32_t numEUsPerSubslice;
  105. uint32_t numSubslicesPerSlice;
  106. uint32_t numSlices;
  107. uint64_t timerResolution;
  108. uint32_t timestampValidBits;
  109. uint32_t kernelTimestampValidBits;
  110. ze_device_uuid_t uuid;
  111. char name[ZE_MAX_DEVICE_NAME];
  112. } ze_device_properties_t;
  113. typedef struct _zes_device_properties_t
  114. {
  115. zes_structure_type_t stype;
  116. void *pNext;
  117. ze_device_properties_t core;
  118. uint32_t numSubdevices;
  119. char serialNumber[ZES_STRING_PROPERTY_SIZE];
  120. char boardNumber[ZES_STRING_PROPERTY_SIZE];
  121. char brandName[ZES_STRING_PROPERTY_SIZE];
  122. char modelName[ZES_STRING_PROPERTY_SIZE];
  123. char vendorName[ZES_STRING_PROPERTY_SIZE];
  124. char driverVersion[ZES_STRING_PROPERTY_SIZE];
  125. } zes_device_properties_t;
  126. typedef struct _zes_device_ext_properties_t
  127. {
  128. zes_structure_type_t stype;
  129. void *pNext;
  130. zes_uuid_t uuid;
  131. zes_device_type_t type;
  132. zes_device_property_flags_t flags;
  133. } zes_device_ext_properties_t;
  134. typedef struct _zes_mem_properties_t
  135. {
  136. zes_structure_type_t stype;
  137. void *pNext;
  138. zes_mem_type_t type;
  139. ze_bool_t onSubdevice;
  140. uint32_t subdeviceId;
  141. zes_mem_loc_t location;
  142. uint64_t physicalSize;
  143. int32_t busWidth;
  144. int32_t numChannels;
  145. } zes_mem_properties_t;
  146. typedef struct _zes_mem_state_t
  147. {
  148. zes_structure_type_t stype;
  149. const void *pNext;
  150. zes_mem_health_t health;
  151. uint64_t free;
  152. uint64_t size;
  153. } zes_mem_state_t;
  154. typedef struct oneapi_handle
  155. {
  156. void *handle;
  157. uint16_t verbose;
  158. ze_result_t (*zesInit)(int);
  159. ze_result_t (*zesDriverGet)(uint32_t *pCount, zes_driver_handle_t *phDrivers);
  160. ze_result_t (*zesDeviceGet)(zes_driver_handle_t hDriver, uint32_t *pCount,
  161. zes_device_handle_t *phDevices);
  162. ze_result_t (*zesDeviceGetProperties)(zes_device_handle_t hDevice,
  163. zes_device_properties_t *pProperties);
  164. ze_result_t (*zesDeviceEnumMemoryModules)(zes_device_handle_t hDevice,
  165. uint32_t *pCount,
  166. zes_mem_handle_t *phMemory);
  167. ze_result_t (*zesMemoryGetProperties)(zes_mem_handle_t hMemory,
  168. zes_mem_properties_t *pProperties);
  169. ze_result_t (*zesMemoryGetState)(zes_mem_handle_t hMemory,
  170. zes_mem_state_t *pState);
  171. } oneapi_handle_t;
  172. typedef struct oneapi_init_resp
  173. {
  174. char *err; // If err is non-null handle is invalid
  175. int num_devices;
  176. oneapi_handle_t oh;
  177. } oneapi_init_resp_t;
  178. typedef struct oneapi_version_resp
  179. {
  180. ze_result_t status;
  181. char *str; // Contains version or error string if status != 0
  182. } oneapi_version_resp_t;
  183. void oneapi_init(char *oneapi_lib_path, oneapi_init_resp_t *resp);
  184. void oneapi_check_vram(oneapi_handle_t rh, mem_info_t *resp);
  185. #endif // __GPU_INFO_INTEL_H__
  186. #endif // __APPLE__