TIOVX User Guide
hwa_dmpac_sde.h
Go to the documentation of this file.
1 /*
2  *
3  * Copyright (c) 2019-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 HWA_DMPAC_SDE_H_
64 #define HWA_DMPAC_SDE_H_
65 
66 #include <VX/vx.h>
67 #include <VX/vx_kernels.h>
68 
69 #ifdef __cplusplus
70 extern "C" {
71 #endif
72 
81 #define TIVX_KERNEL_DMPAC_SDE_NAME "com.ti.hwa.dmpac_sde"
82 
83 
84 /*********************************
85  * DMPAC_SDE Control Commands
86  *********************************/
87 
92 #define TIVX_DMPAC_SDE_CMD_SET_HTS_LIMIT (0x10000000u)
93 
100 #define TIVX_DMPAC_SDE_CMD_GET_ERR_STATUS (0x10000002u)
101 
102 /*********************************
103  * DMPAC_SDE Defines
104  *********************************/
105 
106 /* TODO */
107 
108 /*********************************
109  * DMPAC_SDE STRUCTURES
110  *********************************/
111 
117 typedef struct {
120  uint16_t disparity_min;
121  uint16_t disparity_max;
139  uint16_t confidence_score_map[8];
141 
142 
143 /*********************************
144  * Function Prototypes
145  *********************************/
146 
152 
153 
159 
160 
175 VX_API_ENTRY vx_node VX_API_CALL tivxDmpacSdeNode(vx_graph graph,
176  vx_user_data_object configuration,
177  vx_image left,
178  vx_image right,
179  vx_image output,
180  vx_distribution confidence_histogram);
181 
190 
191 
192 #ifdef __cplusplus
193 }
194 #endif
195 
196 #endif /* HWA_DMPAC_SDE_H_ */
struct _vx_image * vx_image
struct _vx_distribution * vx_distribution
void tivx_dmpac_sde_params_init(tivx_dmpac_sde_params_t *prms)
Function to initialize SDE Parameters.
void tivxUnRegisterHwaTargetDmpacSdeKernels(void)
Function to un-register HWA Kernels on the dmpac_sde Target.
The configuration data structure used by the TIVX_KERNEL_DMPAC_SDE kernel.
struct _vx_user_data_object * vx_user_data_object
The User Data Object. User Data Object is a strongly-typed container for other data structures...
uint16_t reduced_range_search_enable
VX_API_ENTRY vx_node VX_API_CALL tivxDmpacSdeNode(vx_graph graph, vx_user_data_object configuration, vx_image left, vx_image right, vx_image output, vx_distribution confidence_histogram)
[Graph] Creates a DMPAC_SDE Node.
struct _vx_graph * vx_graph
struct _vx_node * vx_node
void tivxRegisterHwaTargetDmpacSdeKernels(void)
Function to register HWA Kernels on the dmpac_sde Target.
vx_status(* VX_API_CALL)(vx_reference *ref)
Callback type used to register release callbacks from object dervied from references.
Definition: vx_reference.h:56