TIOVX User Guide
video_io_capture.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 VIDEO_IO_CAPTURE_H_
64 #define VIDEO_IO_CAPTURE_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_CAPTURE_NAME "com.ti.capture"
82 
83 
84 /*********************************
85  * Capture Control Commands
86  *********************************/
87 
93 #define TIVX_CAPTURE_PRINT_STATISTICS (0x40000000u)
94 
101 #define TIVX_CAPTURE_GET_STATISTICS (0x40000001u)
102 
110 #define TIVX_CAPTURE_REGISTER_ERROR_FRAME (0x40000002u)
111 
112 /* None */
113 
114 /*********************************
115  * Capture Defines
116  *********************************/
117 
122 #if defined(SOC_AM62A)
123 #define TIVX_CAPTURE_MAX_CH (4U)
124 #else
125 #define TIVX_CAPTURE_MAX_CH (16U)
126 #endif
127 
131 #if defined(SOC_J784S4)
132 #define TIVX_CAPTURE_MAX_INST (3U)
133 #elif defined(SOC_AM62A)
134 #define TIVX_CAPTURE_MAX_INST (1U)
135 #else
136 #define TIVX_CAPTURE_MAX_INST (2U)
137 #endif
138 
143 #if defined(SOC_AM62A)
144 #define TIVX_CAPTURE_MAX_STRM (1U)
145 #else
146 #define TIVX_CAPTURE_MAX_STRM (4U)
147 #endif
148 
153 #define TIVX_CAPTURE_LANE_BAND_SPEED_80_TO_100_MBPS ((uint32_t) 0x00U)
154 
158 #define TIVX_CAPTURE_LANE_BAND_SPEED_100_TO_120_MBPS ((uint32_t) 0x01U)
159 
163 #define TIVX_CAPTURE_LANE_BAND_SPEED_120_TO_160_MBPS ((uint32_t) 0x02U)
164 
168 #define TIVX_CAPTURE_LANE_BAND_SPEED_160_TO_200_MBPS ((uint32_t) 0x03U)
169 
173 #define TIVX_CAPTURE_LANE_BAND_SPEED_200_TO_240_MBPS ((uint32_t) 0x04U)
174 
178 #define TIVX_CAPTURE_LANE_BAND_SPEED_240_TO_280_MBPS ((uint32_t) 0x05U)
179 
183 #define TIVX_CAPTURE_LANE_BAND_SPEED_280_TO_320_MBPS ((uint32_t) 0x06U)
184 
188 #define TIVX_CAPTURE_LANE_BAND_SPEED_320_TO_360_MBPS ((uint32_t) 0x07U)
189 
193 #define TIVX_CAPTURE_LANE_BAND_SPEED_360_TO_400_MBPS ((uint32_t) 0x08U)
194 
198 #define TIVX_CAPTURE_LANE_BAND_SPEED_400_TO_480_MBPS ((uint32_t) 0x09U)
199 
203 #define TIVX_CAPTURE_LANE_BAND_SPEED_480_TO_560_MBPS ((uint32_t) 0x0AU)
204 
208 #define TIVX_CAPTURE_LANE_BAND_SPEED_560_TO_640_MBPS ((uint32_t) 0x0BU)
209 
213 #define TIVX_CAPTURE_LANE_BAND_SPEED_640_TO_720_MBPS ((uint32_t) 0x0CU)
214 
218 #define TIVX_CAPTURE_LANE_BAND_SPEED_720_TO_800_MBPS ((uint32_t) 0x0DU)
219 
223 #define TIVX_CAPTURE_LANE_BAND_SPEED_800_TO_880_MBPS ((uint32_t) 0x0EU)
224 
228 #define TIVX_CAPTURE_LANE_BAND_SPEED_880_TO_1040_MBPS ((uint32_t) 0x0FU)
229 
233 #define TIVX_CAPTURE_LANE_BAND_SPEED_1040_TO_1200_MBPS ((uint32_t) 0x10U)
234 
238 #define TIVX_CAPTURE_LANE_BAND_SPEED_1200_TO_1350_MBPS ((uint32_t) 0x11U)
239 
243 #define TIVX_CAPTURE_LANE_BAND_SPEED_1350_TO_1500_MBPS ((uint32_t) 0x12U)
244 
248 #define TIVX_CAPTURE_LANE_BAND_SPEED_1500_TO_1750_MBPS ((uint32_t) 0x13U)
249 
253 #define TIVX_CAPTURE_LANE_BAND_SPEED_1750_TO_2000_MBPS ((uint32_t) 0x14U)
254 
258 #define TIVX_CAPTURE_LANE_BAND_SPEED_2000_TO_2250_MBPS ((uint32_t) 0x15U)
259 
263 #define TIVX_CAPTURE_LANE_BAND_SPEED_2250_TO_2500_MBPS ((uint32_t) 0x16U)
264 
265 /*********************************
266  * Capture STRUCTURES
267  *********************************/
273 typedef struct
274 {
276  uint32_t numDataLanes;
277  uint32_t dataLanesMap[4];
278  uint32_t laneBandSpeed;
279  uint32_t numPixels;
310 
316 typedef struct
317 {
319  uint32_t instId[TIVX_CAPTURE_MAX_INST];
320  uint32_t numInst;
321  uint32_t numCh;
322  uint32_t chVcNum[TIVX_CAPTURE_MAX_CH];
323  uint32_t chInstMap[TIVX_CAPTURE_MAX_CH];
324  uint32_t timeout;
326  uint32_t timeoutInitial;
331 
337 typedef struct
338 {
353  uint32_t errorFrameCount[TIVX_CAPTURE_MAX_INST][TIVX_CAPTURE_MAX_CH];
357  uint32_t overflowCount[TIVX_CAPTURE_MAX_INST];
361  uint32_t spuriousUdmaIntrCount[TIVX_CAPTURE_MAX_INST];
365  uint32_t frontFIFOOvflCount[TIVX_CAPTURE_MAX_INST];
369  uint32_t crcCount[TIVX_CAPTURE_MAX_INST];
373  uint32_t eccCount[TIVX_CAPTURE_MAX_INST];
377  uint32_t correctedEccCount[TIVX_CAPTURE_MAX_INST];
381  uint32_t dataIdErrorCount[TIVX_CAPTURE_MAX_INST];
385  uint32_t invalidAccessCount[TIVX_CAPTURE_MAX_INST];
390  uint32_t invalidSpCount[TIVX_CAPTURE_MAX_INST];
394  uint32_t strmFIFOOvflCount[TIVX_CAPTURE_MAX_INST][TIVX_CAPTURE_MAX_STRM];
400 
401 
402 /*********************************
403  * Function Prototypes
404  *********************************/
405 
411 
412 
418 
419 
457 VX_API_ENTRY vx_node VX_API_CALL tivxCaptureNode(vx_graph graph,
458  vx_user_data_object input,
459  vx_object_array output);
460 
469 
485 
486 #ifdef __cplusplus
487 }
488 #endif
489 
490 #endif /* VIDEO_IO_CAPTURE_H_ */
491 
#define TIVX_CAPTURE_MAX_INST
Maximum number of instances supported in the capture node.
vx_status tivxCaptureRegisterErrorFrame(vx_node node, vx_reference ref)
Function to send error frame to capture node.
#define TIVX_CAPTURE_MAX_STRM
Maximum number of streams supported in a capture module.
The configuration data structure used by the TIVX_KERNEL_CAPTURE kernel.
vx_enum vx_status
struct _vx_reference * vx_reference
Capture status structure used to get the current status.
void tivxUnRegisterVideoIOTargetCaptureKernels(void)
Function to un-register Video IO Kernels on the capture Target.
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...
VX_API_ENTRY vx_node VX_API_CALL tivxCaptureNode(vx_graph graph, vx_user_data_object input, vx_object_array output)
[Graph] Creates a camera capture node.
void tivxRegisterVideoIOTargetCaptureKernels(void)
Function to register Video IO Kernels on the capture Target.
struct _vx_object_array * vx_object_array
struct _vx_graph * vx_graph
struct _vx_node * vx_node
#define TIVX_CAPTURE_MAX_CH
Maximum number of channels supported in the capture node.
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
void tivx_capture_params_init(tivx_capture_params_t *prms)
Function to initialize Capture Parameters.
The CSIRX DRV instance configuration data structure used by the TIVX_KERNEL_CAPTURE kernel...