TI J721E Imaging User Guide
hwa_vpac_viss3.h
Go to the documentation of this file.
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 HWA_VPAC_VISS3_H_
64 #define HWA_VPAC_VISS3_H_
65 
66 #include <VX/vx.h>
67 #include <VX/vx_kernels.h>
68 
69 #ifdef __cplusplus
70 extern "C" {
71 #endif
72 
78 #define TIVX_VPAC_VISS_FCP_NUM_INSTANCES (2U)
79 
83 #define TIVX_VPAC_VISS_MAX_OUTPUTS (6U)
84 
92 #define TIVX_VPAC_VISS_FCP1_DISABLED (0U)
93 
94 #define TIVX_VPAC_VISS_FCP1_INPUT_RFE (1U)
95 
96 #define TIVX_VPAC_VISS_FCP1_INPUT_CAC (2U)
97 
98 #define TIVX_VPAC_VISS_FCP1_INPUT_NSF4 (3U)
99 
100 #define TIVX_VPAC_VISS_FCP1_INPUT_GLBCE (4U)
101 
103 #define TIVX_VPAC_VISS_FCP0 (0U)
104 
105 #define TIVX_VPAC_VISS_FCP1 (1U)
106 
108 #define TIVX_VPAC_VISS_FCP_OUT0 (0U)
109 
110 #define TIVX_VPAC_VISS_FCP_OUT1 (0U)
111 
112 #define TIVX_VPAC_VISS_FCP_OUT2 (1U)
113 
114 #define TIVX_VPAC_VISS_FCP_OUT3 (1U)
115 
116 #define TIVX_VPAC_VISS_FCP_OUT4 (0U)
117 
120 #define TIVX_VPAC_VISS_MAP_FCP_OUTPUT(fcp, output) (output<<1 | fcp)
121 
125 /*********************************
126  * VPAC_VISS STRUCTURES
127  *********************************/
128 
134 typedef struct {
137  uint32_t sensor_dcc_id;
141  uint32_t use_case;
142 
157  uint32_t fcp1_config;
158 
164 
181  uint32_t output_fcp_mapping[5];
182 
185  uint32_t bypass_cac;
186 
189  uint32_t bypass_dwb;
190 
193  uint32_t bypass_nsf4;
194 
197  uint32_t bypass_glbce;
198 
212  uint32_t h3a_in;
213 
223  uint32_t h3a_aewb_af_mode;
224 
239  uint32_t enable_ctx;
243  uint32_t channel_id;
261  uint32_t enable_error_events;
266  uint32_t enable_psa;
268 
269 typedef struct {
275  uint32_t psa_values[TIVX_VPAC_VISS_MAX_OUTPUTS];
276 
282  uint64_t timestamp;
284 
285 
286 /*********************************
287  * Function Prototypes
288  *********************************/
289 
443 VX_API_ENTRY vx_node VX_API_CALL tivxVpacVissNode(vx_graph graph,
444  vx_user_data_object configuration,
445  vx_user_data_object ae_awb_result,
446  vx_user_data_object dcc_buf,
447  tivx_raw_image raw,
448  vx_image output0,
449  vx_image output1,
450  vx_image output2,
451  vx_image output3,
452  vx_image output4,
453  vx_user_data_object h3a_output,
454  vx_distribution histogram0,
455  vx_distribution histogram1,
456  vx_distribution raw_histogram);
457 
458 #ifdef __cplusplus
459 }
460 #endif
461 
462 #endif /* HWA_VPAC_VISS3_H_ */
463 
The Flex Color Processing (FCP) data structure used in the tivx_vpac_viss_params_t structure for prog...
Definition: hwa_vpac_viss_fcp.h:181
#define TIVX_VPAC_VISS_MAX_OUTPUTS
Max Output Channels.
Definition: hwa_vpac_viss3.h:83
VX_API_ENTRY vx_node VX_API_CALL tivxVpacVissNode(vx_graph graph, vx_user_data_object configuration, vx_user_data_object ae_awb_result, vx_user_data_object dcc_buf, tivx_raw_image raw, vx_image output0, vx_image output1, vx_image output2, vx_image output3, vx_image output4, vx_user_data_object h3a_output, vx_distribution histogram0, vx_distribution histogram1, vx_distribution raw_histogram)
[Graph] Creates a VPAC_VISS Node.
#define TIVX_VPAC_VISS_FCP_NUM_INSTANCES
Definition: hwa_vpac_viss3.h:78
The configuration data structure used by the TIVX_KERNEL_VISS kernel.
Definition: hwa_vpac_viss1.h:93
Definition: hwa_vpac_viss1.h:201