TIOVX User Guide
j7_tvm.h
1 /*
2  *
3  * Copyright (c) 2021 Texas Instruments Incorporated
4  *
5  * All rights reserved not granted herein.
6  *
7  * Limited License.
8  *
9  * Texas Instruments Incorporated grants a world-wide, royalty-free, non-exclusive
10  * license under copyrights and patents it now or hereafter owns or controls to make,
11  * have made, use, import, offer to sell and sell ("Utilize") this software subject to the
12  * terms herein. With respect to the foregoing patent license, such license is granted
13  * solely to the extent that any such patent is necessary to Utilize the software alone.
14  * The patent license shall not apply to any combinations which include this software,
15  * other than combinations with devices manufactured by or for TI ("TI Devices").
16  * No hardware patent is licensed hereunder.
17  *
18  * Redistributions must preserve existing copyright notices and reproduce this license
19  * (including the above copyright notice and the disclaimer and (if applicable) source
20  * code license limitations below) in the documentation and/or other materials provided
21  * with the distribution
22  *
23  * Redistribution and use in binary form, without modification, are permitted provided
24  * that the following conditions are met:
25  *
26  * * No reverse engineering, decompilation, or disassembly of this software is
27  * permitted with respect to any software provided in binary form.
28  *
29  * * any redistribution and use are licensed by TI for use only with TI Devices.
30  *
31  * * Nothing shall obligate TI to provide you with source code for the software
32  * licensed and provided to you in object code.
33  *
34  * If software source code is provided to you, modification and redistribution of the
35  * source code are permitted provided that the following conditions are met:
36  *
37  * * any redistribution and use of the source code, including any resulting derivative
38  * works, are licensed by TI for use only with TI Devices.
39  *
40  * * any redistribution and use of any object code compiled from the source code
41  * and any resulting derivative works, are licensed by TI for use only with TI Devices.
42  *
43  * Neither the name of Texas Instruments Incorporated nor the names of its suppliers
44  *
45  * may be used to endorse or promote products derived from this software without
46  * specific prior written permission.
47  *
48  * DISCLAIMER.
49  *
50  * THIS SOFTWARE IS PROVIDED BY TI AND TI'S LICENSORS "AS IS" AND ANY EXPRESS
51  * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
52  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
53  * IN NO EVENT SHALL TI AND TI'S LICENSORS BE LIABLE FOR ANY DIRECT, INDIRECT,
54  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
55  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
56  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
57  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
58  * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
59  * OF THE POSSIBILITY OF SUCH DAMAGE.
60  *
61  */
62 
63 #ifndef J7_TVM_H_
64 #define J7_TVM_H_
65 
66 #include <VX/vx.h>
67 #include <VX/vx_kernels.h>
68 #include <TI/tivx_tensor.h>
69 
70 #ifdef __cplusplus
71 extern "C" {
72 #endif
73 
74 #define TIVX_TVM_J7_CHECKSUM_SIZE (64)
75 
76 /* These correspond to parameter indices of the TVM node
77  * They can be useful to aid in setting replicate parameters if
78  * vxReplicateNode is used.
79  * 0: config: meta data for the kernel call (checksum, num inputs/output, etc)
80  * 1: deploy_mod: tvm c7x deployable module built as shared lib
81  * 2: optional trace output
82  * 3 - ?: in_tensors, out_tensors
83 */
84 #define TIVX_KERNEL_TVM_IN_CONFIG_IDX (0U)
85 #define TIVX_KERNEL_TVM_IN_DEPLOY_MOD_IDX (1U)
86 #define TIVX_KERNEL_TVM_IN_TRACE_DATA_IDX (2U)
87 #define TIVX_KERNEL_TVM_IN_FIRST_TENSOR (3U)
88 #define TIVX_KERNEL_TVM_NUM_BASE_PARAMETERS (3U)
89 #define TIVX_KERNEL_TVM_NUM_MIN_PARAMETERS (TIVX_KERNEL_TVM_NUM_BASE_PARAMETERS + 2)
90 
91 #define TIVX_KERNEL_TVM_MAX_INPUT_TENSORS 16
92 #define TIVX_KERNEL_TVM_MAX_TOTAL_INPUT_TENSOR_NAMES_SIZE 512
93 #define TIVX_KERNEL_TVM_MAX_TOTAL_TENSORS 32
94 #define TIVX_KERNEL_TVM_MAX_TENSOR_DIM 8
95 
97 typedef struct{
98  uint32_t size_in_bytes;
100 
102 typedef struct{
122 
127 typedef struct{
129  vx_uint8 config_checksum[TIVX_TVM_J7_CHECKSUM_SIZE];
130 
132  vx_uint8 deploy_mod_checksum[TIVX_TVM_J7_CHECKSUM_SIZE];
133 
136 
139 
142  vx_uint32 num_output_tensors;
143 
146  vx_uint32 input_names_offset[TIVX_KERNEL_TVM_MAX_INPUT_TENSORS];
147  vx_uint8 input_names[TIVX_KERNEL_TVM_MAX_TOTAL_INPUT_TENSOR_NAMES_SIZE];
148 
150  tivxTVMTensorParams tensors_params[TIVX_KERNEL_TVM_MAX_TOTAL_TENSORS];
151 
154 
157 
159 
175 VX_API_ENTRY vx_node VX_API_CALL tivxTVMNode(vx_graph graph,
176  vx_kernel kernel,
177  vx_reference appParams[],
178  vx_tensor input_tensors[],
179  vx_tensor output_tensors[]);
180 
197  uint32_t num_input_tensors,
198  uint32_t num_output_tensors);
199 
200 #ifdef __cplusplus
201 }
202 #endif
203 
204 #endif /* J7_TVM_H_ */
uint8_t vx_uint8
vx_int32 tvm_rt_trace_size
Definition: j7_tvm.h:114
Interface to Tensor APIs (modeled after OpenVX 1.2 tensor support)
vx_int32 tidl_trace_log_level
Definition: j7_tvm.h:106
struct _vx_tensor * vx_tensor
The multidimensional data object (Tensor).
Definition: tivx_tensor.h:89
int32_t vx_int32
vx_uint64 tvm_rt_trace_ptr
Definition: j7_tvm.h:112
vx_int32 tvm_rt_debug_level
Definition: j7_tvm.h:104
float vx_float32
struct _vx_context * vx_context
vx_float32 max_preempt_delay
Definition: j7_tvm.h:110
vx_int32 tidl_trace_write_level
Definition: j7_tvm.h:108
struct _vx_reference * vx_reference
Parameters describing a TVMRT Tensor.
Definition: j7_tvm.h:97
TVM params structure.
Definition: j7_tvm.h:127
Runtime info needed by TVM C runtime and TIDL.
Definition: j7_tvm.h:102
tvm_tidl_rt_info rt_info
Definition: j7_tvm.h:156
vx_uint32 num_input_tensors
Definition: j7_tvm.h:141
struct _vx_kernel * vx_kernel
vx_uint32 optimize_ivision_activation
Definition: j7_tvm.h:153
vx_int32 tvm_rt_trace_node
Definition: j7_tvm.h:116
VX_API_ENTRY vx_node VX_API_CALL tivxTVMNode(vx_graph graph, vx_kernel kernel, vx_reference appParams[], vx_tensor input_tensors[], vx_tensor output_tensors[])
[Graph] Creates a TVM Node.
vx_kernel tivxAddKernelTVM(vx_context context, uint32_t num_input_tensors, uint32_t num_output_tensors)
Used for the Application to create the tvm kernel from the context.
uint32_t vx_uint32
vx_int32 tvm_rt_core_num
Definition: j7_tvm.h:120
vx_uint32 compute_network_checksum
Definition: j7_tvm.h:138
struct _vx_graph * vx_graph
struct _vx_node * vx_node
vx_uint32 compute_config_checksum
Definition: j7_tvm.h:135
uint64_t vx_uint64
vx_int32 tvm_rt_target_priority
Definition: j7_tvm.h:118
vx_status(* VX_API_CALL)(vx_reference *ref)
Callback type used to register release callbacks from object derived from references.
Definition: vx_reference.h:56