aboutsummaryrefslogtreecommitdiff
path: root/offload/liboffload/API/Symbol.td
blob: c57a2e1b8363241d7cf5490d9349cc0021b4803a (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
//===-- 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 ol_symbol_kind_t : Enum {
  let desc = "The kind of a symbol";
  let etors =[
    Etor<"KERNEL", "a kernel object">,
    Etor<"GLOBAL_VARIABLE", "a global variable">,
  ];
}

def olGetSymbol : Function {
    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 ol_symbol_info_t : Enum {
  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 olGetSymbolInfo : Function {
  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 olGetSymbolInfoSize : Function {
  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."
    ]>,
  ];
}