
Add two new symbol info types for getting the bounds of a global variable. As well as a number of tests for reading/writing to it.
92 lines
3.5 KiB
TableGen
92 lines
3.5 KiB
TableGen
//===-- Symbol.td - Symbol 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 symbol handle.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
def : Enum {
|
|
let name = "ol_symbol_kind_t";
|
|
let desc = "The kind of a symbol";
|
|
let etors =[
|
|
Etor<"KERNEL", "a kernel object">,
|
|
Etor<"GLOBAL_VARIABLE", "a global variable">,
|
|
];
|
|
}
|
|
|
|
def : Function {
|
|
let name = "olGetSymbol";
|
|
let desc = "Get a symbol (kernel or global variable) identified by `Name` in the given program.";
|
|
let details = [
|
|
"Symbol handles are owned by the program and do not need to be manually destroyed."
|
|
];
|
|
let params = [
|
|
Param<"ol_program_handle_t", "Program", "handle of the program", PARAM_IN>,
|
|
Param<"const char*", "Name", "name of the symbol to look up", PARAM_IN>,
|
|
Param<"ol_symbol_kind_t", "Kind", "symbol kind to look up", PARAM_IN>,
|
|
Param<"ol_symbol_handle_t*", "Symbol", "output pointer for the symbol", PARAM_OUT>,
|
|
];
|
|
let returns = [];
|
|
}
|
|
|
|
def : Enum {
|
|
let name = "ol_symbol_info_t";
|
|
let desc = "Supported symbol info.";
|
|
let is_typed = 1;
|
|
let etors = [
|
|
TaggedEtor<"KIND", "ol_symbol_kind_t", "The kind of this symbol.">,
|
|
TaggedEtor<"GLOBAL_VARIABLE_ADDRESS", "void *", "The address in memory for this global variable.">,
|
|
TaggedEtor<"GLOBAL_VARIABLE_SIZE", "size_t", "The size in bytes for this global variable.">,
|
|
];
|
|
}
|
|
|
|
def : Function {
|
|
let name = "olGetSymbolInfo";
|
|
let desc = "Queries the given property of the symbol.";
|
|
let details = [
|
|
"`olGetSymbolInfoSize` can be used to query the storage size "
|
|
"required for the given query."
|
|
];
|
|
let params = [
|
|
Param<"ol_symbol_handle_t", "Symbol", "handle of the symbol", PARAM_IN>,
|
|
Param<"ol_symbol_info_t", "PropName", "type of the info to retrieve", PARAM_IN>,
|
|
Param<"size_t", "PropSize", "the number of bytes pointed to by PropValue.", PARAM_IN>,
|
|
TypeTaggedParam<"void*", "PropValue", "array of bytes holding the info. "
|
|
"If PropSize 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 PropValue is not used.", PARAM_OUT,
|
|
TypeInfo<"PropName" , "PropSize">>
|
|
];
|
|
let returns = [
|
|
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_SYMBOL_KIND", [
|
|
"If the requested info isn't applicable to the type of symbol."
|
|
]>,
|
|
Return<"OL_ERRC_INVALID_SYMBOL">
|
|
];
|
|
}
|
|
|
|
def : Function {
|
|
let name = "olGetSymbolInfoSize";
|
|
let desc = "Returns the storage size of the given symbol query.";
|
|
let details = [];
|
|
let params = [
|
|
Param<"ol_symbol_handle_t", "Symbol", "handle of the symbol", PARAM_IN>,
|
|
Param<"ol_symbol_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_INVALID_SYMBOL">,
|
|
Return<"OL_ERRC_SYMBOL_KIND", [
|
|
"If the requested info isn't applicable to the type of symbol."
|
|
]>,
|
|
];
|
|
}
|