Reland #118503. Added a fix for builds with `-DBUILD_SHARED_LIBS=ON` (see last commit). Otherwise the changes are identical. --- ### New API Previous discussions at the LLVM/Offload meeting have brought up the need for a new API for exposing the functionality of the plugins. This change introduces a very small subset of a new API, which is primarily for testing the offload tooling and demonstrating how a new API can fit into the existing code base without being too disruptive. Exact designs for these entry points and future additions can be worked out over time. The new API does however introduce the bare minimum functionality to implement device discovery for Unified Runtime and SYCL. This means that the `urinfo` and `sycl-ls` tools can be used on top of Offload. A (rough) implementation of a Unified Runtime adapter (aka plugin) for Offload is available [here](https://github.com/callumfare/unified-runtime/tree/offload_adapter). Our intention is to maintain this and use it to implement and test Offload API changes with SYCL. ### Demoing the new API ```sh # From the runtime build directory $ ninja LibomptUnitTests $ OFFLOAD_TRACE=1 ./offload/unittests/OffloadAPI/offload.unittests ``` ### Open questions and future work * Only some of the available device info is exposed, and not all the possible device queries needed for SYCL are implemented by the plugins. A sensible next step would be to refactor and extend the existing device info queries in the plugins. The existing info queries are all strings, but the new API introduces the ability to return any arbitrary type. * It may be sensible at some point for the plugins to implement the new API directly, and the higher level code on top of it could be made generic, but this is more of a long-term possibility.
113 lines
4.2 KiB
TableGen
113 lines
4.2 KiB
TableGen
//===-- Platform.td - Platform definitions for Offload -----*- tablegen -*-===//
|
|
//
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
//
|
|
// This file contains Offload API definitions related to the Platform handle
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
def : Function {
|
|
let name = "olGetPlatform";
|
|
let desc = "Retrieves all available platforms";
|
|
let details = [
|
|
"Multiple calls to this function will return identical platforms handles, in the same order.",
|
|
];
|
|
let params = [
|
|
Param<"uint32_t", "NumEntries",
|
|
"The number of platforms to be added to Platforms. NumEntries must be "
|
|
"greater than zero.",
|
|
PARAM_IN>,
|
|
RangedParam<"ol_platform_handle_t*", "Platforms",
|
|
"Array of handle of platforms. If NumEntries is less than the number of "
|
|
"platforms available, then olGetPlatform shall only retrieve that "
|
|
"number of platforms.",
|
|
PARAM_OUT, Range<"0", "NumEntries">>
|
|
];
|
|
let returns = [
|
|
Return<"OL_ERRC_INVALID_SIZE", [
|
|
"`NumEntries == 0`"
|
|
]>
|
|
];
|
|
}
|
|
|
|
def : Function {
|
|
let name = "olGetPlatformCount";
|
|
let desc = "Retrieves the number of available platforms";
|
|
let params = [
|
|
Param<"uint32_t*",
|
|
"NumPlatforms", "returns the total number of platforms available.",
|
|
PARAM_OUT>
|
|
];
|
|
let returns = [];
|
|
}
|
|
|
|
def : Enum {
|
|
let name = "ol_platform_info_t";
|
|
let desc = "Supported platform info";
|
|
let is_typed = 1;
|
|
let etors = [
|
|
TaggedEtor<"NAME", "char[]", "The string denoting name of the platform. The size of the info needs to be dynamically queried.">,
|
|
TaggedEtor<"VENDOR_NAME", "char[]", "The string denoting name of the vendor of the platform. The size of the info needs to be dynamically queried.">,
|
|
TaggedEtor<"VERSION", "char[]", "The string denoting the version of the platform. The size of the info needs to be dynamically queried.">,
|
|
TaggedEtor<"BACKEND", "ol_platform_backend_t", "The native backend of the platform.">
|
|
];
|
|
}
|
|
|
|
def : Enum {
|
|
let name = "ol_platform_backend_t";
|
|
let desc = "Identifies the native backend of the platform";
|
|
let etors =[
|
|
Etor<"UNKNOWN", "The backend is not recognized">,
|
|
Etor<"CUDA", "The backend is CUDA">,
|
|
Etor<"AMDGPU", "The backend is AMDGPU">,
|
|
];
|
|
}
|
|
|
|
def : Function {
|
|
let name = "olGetPlatformInfo";
|
|
let desc = "Queries the given property of the platform";
|
|
let details = [
|
|
"`olGetPlatformInfoSize` can be used to query the storage size "
|
|
"required for the given query."
|
|
];
|
|
let params = [
|
|
Param<"ol_platform_handle_t", "Platform", "handle of the platform", PARAM_IN>,
|
|
Param<"ol_platform_info_t", "PropName", "type of the info to retrieve", PARAM_IN>,
|
|
Param<"size_t", "PropSize", "the number of bytes pointed to by pPlatformInfo.", PARAM_IN>,
|
|
TypeTaggedParam<"void*", "PropValue", "array of bytes holding the info. "
|
|
"If Size is not equal to or greater to the real number of bytes needed to return the info "
|
|
"then the OL_ERRC_INVALID_SIZE error is returned and pPlatformInfo is not used.", PARAM_OUT,
|
|
TypeInfo<"PropName" , "PropSize">>
|
|
];
|
|
let returns = [
|
|
Return<"OL_ERRC_UNSUPPORTED_ENUMERATION", [
|
|
"If `PropName` is not supported by the platform."
|
|
]>,
|
|
Return<"OL_ERRC_INVALID_SIZE", [
|
|
"`PropSize == 0`",
|
|
"If `PropSize` is less than the real number of bytes needed to return the info."
|
|
]>,
|
|
Return<"OL_ERRC_INVALID_PLATFORM">
|
|
];
|
|
}
|
|
|
|
def : Function {
|
|
let name = "olGetPlatformInfoSize";
|
|
let desc = "Returns the storage size of the given platform query";
|
|
let details = [];
|
|
let params = [
|
|
Param<"ol_platform_handle_t", "Platform", "handle of the platform", PARAM_IN>,
|
|
Param<"ol_platform_info_t", "PropName", "type of the info to query", PARAM_IN>,
|
|
Param<"size_t*", "PropSizeRet", "pointer to the number of bytes required to store the query", PARAM_OUT>
|
|
];
|
|
let returns = [
|
|
Return<"OL_ERRC_UNSUPPORTED_ENUMERATION", [
|
|
"If `PropName` is not supported by the platform."
|
|
]>,
|
|
Return<"OL_ERRC_INVALID_PLATFORM">
|
|
];
|
|
}
|