feature: Define L0 Driver API for Driver Version String
Related-To: NEO-11752 - Adds zeIntelGetDriverVersionString to report the driver version string to the user in the format: Major.Minor.Patch+Optional Signed-off-by: Neil R. Spruit <neil.r.spruit@intel.com>
This commit is contained in:
parent
cf71353d84
commit
0daa0335cf
|
@ -12,5 +12,6 @@
|
||||||
#cmakedefine NEO_REVISION "${NEO_REVISION}"
|
#cmakedefine NEO_REVISION "${NEO_REVISION}"
|
||||||
|
|
||||||
#define NEO_VERSION_BUILD ${NEO_VERSION_BUILD}
|
#define NEO_VERSION_BUILD ${NEO_VERSION_BUILD}
|
||||||
|
#define NEO_VERSION_HOTFIX ${NEO_VERSION_HOTFIX}
|
||||||
|
|
||||||
#endif /* DRIVER_VERSION_H */
|
#endif /* DRIVER_VERSION_H */
|
||||||
|
|
|
@ -5,9 +5,16 @@
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#include "shared/source/helpers/string.h"
|
||||||
|
|
||||||
#include "level_zero/api/driver_experimental/public/zex_api.h"
|
#include "level_zero/api/driver_experimental/public/zex_api.h"
|
||||||
#include "level_zero/core/source/driver/driver.h"
|
#include "level_zero/core/source/driver/driver.h"
|
||||||
#include "level_zero/core/source/driver/driver_handle.h"
|
#include "level_zero/core/source/driver/driver_handle.h"
|
||||||
|
#include "level_zero/include/ze_intel_gpu.h"
|
||||||
|
|
||||||
|
#include "driver_version.h"
|
||||||
|
|
||||||
|
#include <string>
|
||||||
|
|
||||||
namespace L0 {
|
namespace L0 {
|
||||||
|
|
||||||
|
@ -36,6 +43,25 @@ zexDriverGetHostPointerBaseAddress(
|
||||||
|
|
||||||
} // namespace L0
|
} // namespace L0
|
||||||
|
|
||||||
|
ze_result_t ZE_APICALL
|
||||||
|
zeIntelGetDriverVersionString(
|
||||||
|
ze_driver_handle_t hDriver,
|
||||||
|
char *pDriverVersion,
|
||||||
|
size_t *pVersionSize) {
|
||||||
|
ze_api_version_t apiVersion;
|
||||||
|
L0::DriverHandle::fromHandle(hDriver)->getApiVersion(&apiVersion);
|
||||||
|
std::string driverVersionString = std::to_string(ZE_MAJOR_VERSION(apiVersion)) + "." + std::to_string(ZE_MINOR_VERSION(apiVersion)) + "." + std::to_string(NEO_VERSION_BUILD);
|
||||||
|
if (NEO_VERSION_HOTFIX > 0) {
|
||||||
|
driverVersionString += "+" + std::to_string(NEO_VERSION_HOTFIX);
|
||||||
|
}
|
||||||
|
if (*pVersionSize == 0) {
|
||||||
|
*pVersionSize = strlen(driverVersionString.c_str());
|
||||||
|
return ZE_RESULT_SUCCESS;
|
||||||
|
}
|
||||||
|
driverVersionString.copy(pDriverVersion, *pVersionSize, 0);
|
||||||
|
return ZE_RESULT_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
extern "C" {
|
extern "C" {
|
||||||
|
|
||||||
ZE_APIEXPORT ze_result_t ZE_APICALL
|
ZE_APIEXPORT ze_result_t ZE_APICALL
|
||||||
|
|
|
@ -37,5 +37,6 @@ const std::vector<std::pair<std::string, uint32_t>> DriverHandleImp::extensionsS
|
||||||
{ZE_EVENT_POOL_COUNTER_BASED_EXP_NAME, ZE_EVENT_POOL_COUNTER_BASED_EXP_VERSION_CURRENT},
|
{ZE_EVENT_POOL_COUNTER_BASED_EXP_NAME, ZE_EVENT_POOL_COUNTER_BASED_EXP_VERSION_CURRENT},
|
||||||
{ZE_INTEL_COMMAND_LIST_MEMORY_SYNC, ZE_INTEL_COMMAND_LIST_MEMORY_SYNC_EXP_VERSION_CURRENT},
|
{ZE_INTEL_COMMAND_LIST_MEMORY_SYNC, ZE_INTEL_COMMAND_LIST_MEMORY_SYNC_EXP_VERSION_CURRENT},
|
||||||
{ZEX_INTEL_EVENT_SYNC_MODE_EXP_NAME, ZEX_INTEL_EVENT_SYNC_MODE_EXP_VERSION_CURRENT},
|
{ZEX_INTEL_EVENT_SYNC_MODE_EXP_NAME, ZEX_INTEL_EVENT_SYNC_MODE_EXP_VERSION_CURRENT},
|
||||||
|
{ZE_INTEL_GET_DRIVER_VERSION_STRING_EXP_NAME, ZE_INTEL_GET_DRIVER_VERSION_STRING_EXP_VERSION_CURRENT},
|
||||||
};
|
};
|
||||||
} // namespace L0
|
} // namespace L0
|
||||||
|
|
|
@ -9,6 +9,7 @@
|
||||||
|
|
||||||
#include "level_zero/api/driver_experimental/public/zex_api.h"
|
#include "level_zero/api/driver_experimental/public/zex_api.h"
|
||||||
#include "level_zero/api/extensions/public/ze_exp_ext.h"
|
#include "level_zero/api/extensions/public/ze_exp_ext.h"
|
||||||
|
#include "level_zero/include/ze_intel_gpu.h"
|
||||||
|
|
||||||
#include <cstring>
|
#include <cstring>
|
||||||
|
|
||||||
|
@ -41,6 +42,7 @@ void *ExtensionFunctionAddressHelper::getExtensionFunctionAddress(const std::str
|
||||||
RETURN_FUNC_PTR_IF_EXIST(zeMemGetPitchFor2dImage);
|
RETURN_FUNC_PTR_IF_EXIST(zeMemGetPitchFor2dImage);
|
||||||
RETURN_FUNC_PTR_IF_EXIST(zeImageGetDeviceOffsetExp);
|
RETURN_FUNC_PTR_IF_EXIST(zeImageGetDeviceOffsetExp);
|
||||||
RETURN_FUNC_PTR_IF_EXIST(zexDeviceGetConcurrentMetricGroups);
|
RETURN_FUNC_PTR_IF_EXIST(zexDeviceGetConcurrentMetricGroups);
|
||||||
|
RETURN_FUNC_PTR_IF_EXIST(zeIntelGetDriverVersionString);
|
||||||
#undef RETURN_FUNC_PTR_IF_EXIST
|
#undef RETURN_FUNC_PTR_IF_EXIST
|
||||||
|
|
||||||
return ExtensionFunctionAddressHelper::getAdditionalExtensionFunctionAddress(functionName);
|
return ExtensionFunctionAddressHelper::getAdditionalExtensionFunctionAddress(functionName);
|
||||||
|
|
|
@ -6105,5 +6105,9 @@ TEST(ExtensionLookupTest, givenLookupMapWhenAskingForBindlessImageExtensionFunct
|
||||||
EXPECT_NE(nullptr, ExtensionFunctionAddressHelper::getExtensionFunctionAddress("zeImageGetDeviceOffsetExp"));
|
EXPECT_NE(nullptr, ExtensionFunctionAddressHelper::getExtensionFunctionAddress("zeImageGetDeviceOffsetExp"));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
TEST(ExtensionLookupTest, givenLookupMapWhenAskingForZeIntelGetDriverVersionStringThenReturnCorrectValue) {
|
||||||
|
EXPECT_NE(nullptr, ExtensionFunctionAddressHelper::getExtensionFunctionAddress("zeIntelGetDriverVersionString"));
|
||||||
|
}
|
||||||
|
|
||||||
} // namespace ult
|
} // namespace ult
|
||||||
} // namespace L0
|
} // namespace L0
|
||||||
|
|
|
@ -39,6 +39,7 @@
|
||||||
#include "level_zero/core/test/unit_tests/mocks/mock_builtin_functions_lib_impl.h"
|
#include "level_zero/core/test/unit_tests/mocks/mock_builtin_functions_lib_impl.h"
|
||||||
#include "level_zero/core/test/unit_tests/mocks/mock_driver.h"
|
#include "level_zero/core/test/unit_tests/mocks/mock_driver.h"
|
||||||
#include "level_zero/core/test/unit_tests/mocks/mock_driver_handle.h"
|
#include "level_zero/core/test/unit_tests/mocks/mock_driver_handle.h"
|
||||||
|
#include "level_zero/include/ze_intel_gpu.h"
|
||||||
|
|
||||||
#include "driver_version.h"
|
#include "driver_version.h"
|
||||||
|
|
||||||
|
@ -1264,6 +1265,7 @@ TEST_F(DriverExperimentalApiTest, whenRetrievingApiFunctionThenExpectProperPoint
|
||||||
decltype(&zexDriverReleaseImportedPointer) expectedRelease = L0::zexDriverReleaseImportedPointer;
|
decltype(&zexDriverReleaseImportedPointer) expectedRelease = L0::zexDriverReleaseImportedPointer;
|
||||||
decltype(&zexDriverGetHostPointerBaseAddress) expectedGet = L0::zexDriverGetHostPointerBaseAddress;
|
decltype(&zexDriverGetHostPointerBaseAddress) expectedGet = L0::zexDriverGetHostPointerBaseAddress;
|
||||||
decltype(&zexKernelGetBaseAddress) expectedKernelGetBaseAddress = L0::zexKernelGetBaseAddress;
|
decltype(&zexKernelGetBaseAddress) expectedKernelGetBaseAddress = L0::zexKernelGetBaseAddress;
|
||||||
|
decltype(&zeIntelGetDriverVersionString) expectedIntelGetDriverVersionString = zeIntelGetDriverVersionString;
|
||||||
|
|
||||||
void *funPtr = nullptr;
|
void *funPtr = nullptr;
|
||||||
|
|
||||||
|
@ -1282,6 +1284,10 @@ TEST_F(DriverExperimentalApiTest, whenRetrievingApiFunctionThenExpectProperPoint
|
||||||
result = zeDriverGetExtensionFunctionAddress(driverHandle, "zexKernelGetBaseAddress", &funPtr);
|
result = zeDriverGetExtensionFunctionAddress(driverHandle, "zexKernelGetBaseAddress", &funPtr);
|
||||||
EXPECT_EQ(ZE_RESULT_SUCCESS, result);
|
EXPECT_EQ(ZE_RESULT_SUCCESS, result);
|
||||||
EXPECT_EQ(expectedKernelGetBaseAddress, reinterpret_cast<decltype(&zexKernelGetBaseAddress)>(funPtr));
|
EXPECT_EQ(expectedKernelGetBaseAddress, reinterpret_cast<decltype(&zexKernelGetBaseAddress)>(funPtr));
|
||||||
|
|
||||||
|
result = zeDriverGetExtensionFunctionAddress(driverHandle, "zeIntelGetDriverVersionString", &funPtr);
|
||||||
|
EXPECT_EQ(ZE_RESULT_SUCCESS, result);
|
||||||
|
EXPECT_EQ(expectedIntelGetDriverVersionString, reinterpret_cast<decltype(&zeIntelGetDriverVersionString)>(funPtr));
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(DriverExperimentalApiTest, givenHostPointerApiExistWhenImportingPtrThenExpectProperBehavior) {
|
TEST_F(DriverExperimentalApiTest, givenHostPointerApiExistWhenImportingPtrThenExpectProperBehavior) {
|
||||||
|
@ -1303,5 +1309,17 @@ TEST_F(DriverExperimentalApiTest, givenHostPointerApiExistWhenImportingPtrThenEx
|
||||||
EXPECT_EQ(ZE_RESULT_SUCCESS, result);
|
EXPECT_EQ(ZE_RESULT_SUCCESS, result);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
TEST_F(DriverExperimentalApiTest, givenGetVersionStringAPIExistsThenGetCurrentVersionString) {
|
||||||
|
size_t sizeOfDriverString = 0;
|
||||||
|
auto result = zeIntelGetDriverVersionString(driverHandle, nullptr, &sizeOfDriverString);
|
||||||
|
EXPECT_EQ(ZE_RESULT_SUCCESS, result);
|
||||||
|
EXPECT_NE(sizeOfDriverString, 0u);
|
||||||
|
char *driverVersionString = reinterpret_cast<char *>(malloc(sizeOfDriverString * sizeof(char)));
|
||||||
|
result = zeIntelGetDriverVersionString(driverHandle, driverVersionString, &sizeOfDriverString);
|
||||||
|
EXPECT_EQ(ZE_RESULT_SUCCESS, result);
|
||||||
|
EXPECT_NE("", driverVersionString);
|
||||||
|
free(driverVersionString);
|
||||||
|
}
|
||||||
|
|
||||||
} // namespace ult
|
} // namespace ult
|
||||||
} // namespace L0
|
} // namespace L0
|
||||||
|
|
|
@ -0,0 +1,82 @@
|
||||||
|
<!---
|
||||||
|
|
||||||
|
Copyright (C) 2024 Intel Corporation
|
||||||
|
|
||||||
|
SPDX-License-Identifier: MIT
|
||||||
|
|
||||||
|
-->
|
||||||
|
|
||||||
|
# Get Driver Versiopn String
|
||||||
|
|
||||||
|
* [Overview](#Overview)
|
||||||
|
* [Definitions](#Definitions)
|
||||||
|
|
||||||
|
# Overview
|
||||||
|
|
||||||
|
To support reporting the Level Zero gpu driver version as a set string value, a new extension API `zeIntelGetDriverVersionString` to retrieve a specific version string from the driver has been created.
|
||||||
|
|
||||||
|
## Outline
|
||||||
|
|
||||||
|
`zeIntelGetDriverVersionString` reports the driver version in the form: `Major.Minor.Patch+Optional`.
|
||||||
|
|
||||||
|
Example Versions:
|
||||||
|
|
||||||
|
| Level Zero Package Version | Level Zero Driver Version String
|
||||||
|
|---|---|
|
||||||
|
| 1.3.27642.40 | 1.3.27642+40 |
|
||||||
|
| 1.3.27191 | 1.3.27191
|
||||||
|
|
||||||
|
|
||||||
|
# Definitions
|
||||||
|
|
||||||
|
```cpp
|
||||||
|
#define ZE_INTEL_GET_DRIVER_VERSION_STRING_EXP_NAME "ZE_intel_get_driver_version_string"
|
||||||
|
```
|
||||||
|
|
||||||
|
## Interfaces
|
||||||
|
|
||||||
|
```cpp
|
||||||
|
/// @brief Query to read the Intel Level Zero Driver Version String
|
||||||
|
///
|
||||||
|
/// @details
|
||||||
|
/// - The application may call this function from simultaneous threads.
|
||||||
|
/// - The implementation of this function should be lock-free.
|
||||||
|
/// - The Driver Version String will be in the format:
|
||||||
|
/// - Major.Minor.Patch+Optional per semver guidelines https://semver.org/#spec-item-10
|
||||||
|
/// @returns
|
||||||
|
/// - ::ZE_RESULT_SUCCESS
|
||||||
|
ze_result_t ZE_APICALL
|
||||||
|
zeIntelGetDriverVersionString(
|
||||||
|
ze_driver_handle_t hDriver, ///< [in] Driver handle whose version is being read.
|
||||||
|
char *pDriverVersion, ///< [in,out] pointer to driver version string.
|
||||||
|
size_t *pVersionSize); ///< [in,out] pointer to the size of the driver version string.
|
||||||
|
///< if size is zero, then the size of the version string is returned.
|
||||||
|
```
|
||||||
|
|
||||||
|
## Programming example
|
||||||
|
|
||||||
|
```cpp
|
||||||
|
//Check for extension existence
|
||||||
|
uint32_t count = 0;
|
||||||
|
bool supported = false;
|
||||||
|
zeDriverGetExtensionProperties(driverHandle, &count, nullptr);
|
||||||
|
|
||||||
|
std::vector<ze_driver_extension_properties_t> properties(count);
|
||||||
|
memset(properties.data(), 0,
|
||||||
|
sizeof(ze_driver_extension_properties_t) * count);
|
||||||
|
zeDriverGetExtensionProperties(driverHandle, &count, properties.data());
|
||||||
|
for (auto &extension : properties) {
|
||||||
|
if (strcmp(extension.name, ZE_intel_get_driver_version_string) == 0) {
|
||||||
|
supported = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
//Call the driver extension if it exists.
|
||||||
|
if (supported) {
|
||||||
|
zeDriverGetExtensionFunctionAddress(driverHandle, "zeIntelGetDriverVersionString", pfnGetDriverVersionFn);
|
||||||
|
size_t sizeOfDriverString = 0;
|
||||||
|
pfnGetDriverVersionFn(driverHandle, nullptr, &sizeOfDriverString);
|
||||||
|
char *driverVersionString = reinterpret_cast<char *>(malloc(sizeOfDriverString * sizeof(char)));
|
||||||
|
pfnGetDriverVersionFn(driverHandle, driverVersionString, &sizeOfDriverString);
|
||||||
|
free(driverVersionString);
|
||||||
|
}
|
||||||
|
```
|
|
@ -185,6 +185,35 @@ typedef enum _zex_intel_queue_copy_operations_offload_hint_exp_version_t {
|
||||||
ZEX_INTEL_QUEUE_COPY_OPERATIONS_OFFLOAD_HINT_EXP_VERSION_FORCE_UINT32 = 0x7fffffff
|
ZEX_INTEL_QUEUE_COPY_OPERATIONS_OFFLOAD_HINT_EXP_VERSION_FORCE_UINT32 = 0x7fffffff
|
||||||
} zex_intel_queue_copy_operations_offload_hint_exp_version_t;
|
} zex_intel_queue_copy_operations_offload_hint_exp_version_t;
|
||||||
|
|
||||||
|
#ifndef ZE_INTEL_GET_DRIVER_VERSION_STRING_EXP_NAME
|
||||||
|
/// @brief Extension name for query to read the Intel Level Zero Driver Version String
|
||||||
|
#define ZE_INTEL_GET_DRIVER_VERSION_STRING_EXP_NAME "ZE_intel_get_driver_version_string"
|
||||||
|
#endif // ZE_INTEL_GET_DRIVER_VERSION_STRING_EXP_NAME
|
||||||
|
|
||||||
|
///////////////////////////////////////////////////////////////////////////////
|
||||||
|
/// @brief Query to read the Intel Level Zero Driver Version String extension version(s)
|
||||||
|
typedef enum _ze_intel_get_driver_version_string_exp_version_t {
|
||||||
|
ZE_INTEL_GET_DRIVER_VERSION_STRING_EXP_VERSION_1_0 = ZE_MAKE_VERSION(1, 0), ///< version 1.0
|
||||||
|
ZE_INTEL_GET_DRIVER_VERSION_STRING_EXP_VERSION_CURRENT = ZE_MAKE_VERSION(1, 0), ///< latest known version
|
||||||
|
ZE_INTEL_GET_DRIVER_VERSION_STRING_EXP_VERSION_FORCE_UINT32 = 0x7fffffff
|
||||||
|
} ze_intel_get_driver_version_string_exp_version_t;
|
||||||
|
|
||||||
|
/// @brief Query to read the Intel Level Zero Driver Version String
|
||||||
|
///
|
||||||
|
/// @details
|
||||||
|
/// - The application may call this function from simultaneous threads.
|
||||||
|
/// - The implementation of this function should be lock-free.
|
||||||
|
/// - The Driver Version String will be in the format:
|
||||||
|
/// - Major.Minor.Patch+Optional per semver guidelines https://semver.org/#spec-item-10
|
||||||
|
/// @returns
|
||||||
|
/// - ::ZE_RESULT_SUCCESS
|
||||||
|
ze_result_t ZE_APICALL
|
||||||
|
zeIntelGetDriverVersionString(
|
||||||
|
ze_driver_handle_t hDriver, ///< [in] Driver handle whose version is being read.
|
||||||
|
char *pDriverVersion, ///< [in,out] pointer to driver version string.
|
||||||
|
size_t *pVersionSize); ///< [in,out] pointer to the size of the driver version string.
|
||||||
|
///< if size is zero, then the size of the version string is returned.
|
||||||
|
|
||||||
#if defined(__cplusplus)
|
#if defined(__cplusplus)
|
||||||
} // extern "C"
|
} // extern "C"
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -74,6 +74,10 @@ if(NOT DEFINED NEO_VERSION_BUILD)
|
||||||
set(NEO_VERSION_BUILD 0)
|
set(NEO_VERSION_BUILD 0)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
if(NOT DEFINED NEO_VERSION_HOTFIX)
|
||||||
|
set(NEO_VERSION_HOTFIX 0)
|
||||||
|
endif()
|
||||||
|
|
||||||
# OpenCL pacakge version
|
# OpenCL pacakge version
|
||||||
set(NEO_OCL_DRIVER_VERSION "${NEO_OCL_VERSION_MAJOR}.${NEO_OCL_VERSION_MINOR}.${NEO_VERSION_BUILD}")
|
set(NEO_OCL_DRIVER_VERSION "${NEO_OCL_VERSION_MAJOR}.${NEO_OCL_VERSION_MINOR}.${NEO_VERSION_BUILD}")
|
||||||
|
|
||||||
|
@ -83,3 +87,4 @@ set(NEO_L0_VERSION_MINOR 3)
|
||||||
|
|
||||||
# Remove leading zeros
|
# Remove leading zeros
|
||||||
string(REGEX REPLACE "^0+([0-9]+)" "\\1" NEO_VERSION_BUILD "${NEO_VERSION_BUILD}")
|
string(REGEX REPLACE "^0+([0-9]+)" "\\1" NEO_VERSION_BUILD "${NEO_VERSION_BUILD}")
|
||||||
|
string(REGEX REPLACE "^0+([0-9]+)" "\\1" NEO_VERSION_HOTFIX "${NEO_VERSION_HOTFIX}")
|
||||||
|
|
Loading…
Reference in New Issue